学习LINQ时,经常会遇到LINQ使用Skip操作问题,这里将介绍LINQ使用Skip操作问题的解决方法。
LINQ使用Skip操作
LINQ支持许多内置的标准查询操作。如果你在类之前加入"using System.Query"语句你就可以在代码 中使用这些操作。例如,如果我要列出第2远到第6远的城市,我就可以使用象下面这样的编码:
- using System;
- using System.Web.UI;
- using System.Query;
- public partial class Step4 : System.Web.UI.Page
- {
- protected void Page_Load(object sender, EventArgs e)
- {
- TravelOrganizer travel = new TravelOrganizer();
- GridView1.DataSource = (from location in travel.PlacesVisited
- & nbsp; orderby location.Distance descending
- & nbsp; select location).Skip(1).Take(5);
- GridView1.DataBind();
- }
- }
注意我是怎么通过距离的远近来对结果进行排序的。然后我使 用Skip操作来跳过***个城市,然后使用Take操作来只返回5个结 果。
NET标准查询操作的真正强大之处在于,这些操作不是写死 的(hard-coded ),任何开发人员都可以添加新的或替换其中的操作。这就可以支持实现非常强有力的特定 域(domain specific)操作。例如,当你在LINQ使用Skip操作时,DLINQ实际上是把这些操作转换成 服务器端分页的后台SQL逻辑,这样,只有少量的记录从数据库返回,不管数据表中是否有十几万条数据。这 意味着我们可以在大量关系数据之上很轻易地实现高效的web数据分页。注意:在LINQ正式发行之前,你可以 使用这里提到的技术。
【编辑推荐】