神仙?妖怪?谢谢!

Just do it...

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

演练:检索和显示来自域服务的数据
想要在Silverlight应用程序中检索数据,我们调用域上下文中的方法,这些方法对应着域服务中我们想要使用的查询方法。例如,在域服务中有个名为GetProducts的方法,那么在与上下文中有个名为 GetProductsQuery的方法。在SL应用程序中,我们调用GetProductsQuery方法,此方法返回一个 EntityQuery(TEntity)对象。
在SL应用程序中,我们可以对查询应用额外的过滤来限制返回的实体。虽然一个查询方法可以返回产品表的所有记录,但可能我们只想显示价格低于100的产品。我们使用LINQ和LINQ运算符的子集来改变从查询返回的结果。下面列出了可用的查询运算符:
   1.  Where
   2.  OrderBy
   3.  ThenBy
   4.  Skip
   5.  Take
当应用了额外的过滤时,我们把EntityQuery(TEntity)对象传递给Load方法的一个参数,来运行查询和得到结果。如果查询有一个IsComposable属性设为false的QueryAttribute([Query(IsComposable = false)])。我们不可以在查询上应用额外的过滤。通常,只有返回单一实体的查询把IsComposable设置为false。
我们可以把数据绑定到任何显示数据的SL控件。DataGrid控件可以以表格的格式来显示数据。

 

演练
   1.  打开RIAServicesExample解决方案。
   2.  在Silverlight应用程序中,打开MainPage.xaml的代码文件。
   3.  调用GetCustomersQuery方法来创建EntityQuery(TEntity)实例。
   4.  使用可用的查询运算符来过滤客户。
   5.  把查询对象传递给DomainContext的Load方法,并报返回结果赋给LoadOperation(TEntity).
下面的代码演示如何从域服务检索客户信息。并且过滤电话号码以583开始的客户,同时以LastName按字母排序。结果显示在DataGrid控件中。

代码
 1 public partial class MainPage : UserControl   
 2 {   
 3     private CustomerDomainContext _customerContext = new CustomerDomainContext();   
 4     public MainPage()   
 5     {   
 6         InitializeComponent();   
 7         EntityQuery<customer> query =    
 8             from c in _customerContext.GetCustomersQuery()   
 9             where c.Phone.StartsWith("583")   
10             orderby c.LastName   
11             select c;   
12         LoadOperation<customer> loadOp = this._customerContext.Load(query);   
13         CustomerGrid.ItemsSource = loadOp.Entities;   
14     }   
15 }

 

 
结果显示如下:

 


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/blackant2/archive/2010/04/08/5462131.aspx

posted on 2010-06-05 02:34  E.Trock  阅读(743)  评论(0编辑  收藏  举报