首页 | 互联网 | IT动态 | IT培训 | Cisco | Windows | Linux | Java | .Net | Oracle | 软件测试 | C/C++ | 嵌入式开发 | 存储世界 | 服务器
网络设备 | IDC | 安全 | 求职招聘 | 数字网校 | 网页设计 | 平面设计 | 技术专题 | 电子书下载 | 教学视频 | 源码下载 | 搜索 | 博客 | 论坛
中国IT实验室Dotnet频道
中国IT教育
Google
首页 ASP.NET  C#  XML/WebService ADO.NET VC.NET VB.NET .NET 资讯动态 专题 RSS订阅 讨论 下载
您现在的位置: 中国IT实验室 >> Dotnet >> C# >> 正文

C#通过查询结果进行分页

     通过查询结果进行分页就是以结果集的子集处理查询结果的过程,这样,每次返回给用户的只是当前页面的数据大小。
  
  DataAdapter对象通过重载Fill方法提供了返回当前页面数据的功能。然而,这种方法对大数据量的查询结果并不是最好的选择,这是因为:当DataAdapter用请求的结果填充DataTable或者DataSet时,数据库返回的资源仍是全部的查询结果,只是在返回时附加了额外的限定条件才返回了少量的记录集的。
  
  要使用Fill方法返回当前一页的记录,需要指定开始记录startRecord,和当前页的最大记录数maxRecords。
  
  下面的例子用来返回一页为5条记录的第一页的查询结果:
  
  [VB.NET]
  
  Dim currentIndex As Integer = 0
  Dim pageSize As Integer = 5
  
  Dim orderSQL As String = "SELECT * FROM Orders ORDER BY OrderID"
  Dim myDA As SqlDataAdapter = New SqlDataAdapter(orderSQL, nwindConn)
  
  Dim myDS As DataSet = New DataSet()
  myDA.Fill(myDS, currentIndex, pageSize, "Orders")
  [C#]
  
  int currentIndex = 0;
  int pageSize = 5;
  
  string orderSQL = "SELECT * FROM Orders ORDER BY OrderID";
  SqlDataAdapter myDA = new SqlDataAdapter(orderSQL, nwindConn);
  
  DataSet myDS = new DataSet();
  myDA.Fill(myDS, currentIndex, pageSize, "Orders");
  在上面的例子中,DataSet只填充了5条记录,但返回的仍是整个Orders表。如果要达到填充几条返回几天的目的,在SQL语句中使用TOP和WHERE从句即可。例如:
  
  [VB.NET]
  
  Dim pageSize As Integer = 5
  
  Dim orderSQL As String = "SELECT TOP " & pageSize & " * FROM Orders ORDER BY OrderID"
  Dim myDA As SqlDataAdapter = New SqlDataAdapter(orderSQL, nwindConn)
  
  Dim myDS As DataSet = New DataSet()
  myDA.Fill(myDS, "Orders")
  [C#]
  
  int pageSize = 5;
  
  string orderSQL = "SELECT TOP " + pageSize + " * FROM Orders ORDER BY OrderID";
  SqlDataAdapter myDA = new SqlDataAdapter(orderSQL, nwindConn);
  
  DataSet myDS = new DataSet();
  myDA.Fill(myDS, "Orders");
  此时需要注意的是:用这种方法进行的分页,必须自己维护记录排序的唯一标识,为了向下一页请求传递唯一的ID,我们必须象下面那样:
  
  [VB.NET]
  Dim lastRecord As String = myDS.Tables("Orders").Rows(pageSize - 1)("OrderID").ToString()
  [C#]
  string lastRecord = myDS.Tables["Orders"].Rows[pageSize - 1]["OrderID"].ToString();
  下面的代码在Table填充之前进行了清空:
  
  [VB.NET]
  currentIndex = currentIndex + pageSize
  
  myDS.Tables("Orders").Rows.Clear()
  
  myDA.Fill(myDS, currentIndex, pageSize, "Orders")
  [C#]
  currentIndex += pageSize;
  
  myDS.Tables["Orders"].Rows.Clear();
  
  myDA.Fill(myDS, currentIndex, pageSize, "Orders");
  下面是完整的代码:
  
  [C#]
  
  using System;
  using System.Data;
  using System.Data.SqlClient;
  using System.Drawing;
  using System.Windows.Forms;
  
  public class PagingSample: Form
  {
   // Form 控件.
   Button prevBtn = new Button();
   Button nextBtn = new Button();
  
   static DataGrid myGrid = new DataGrid();
   static Label pageLbl = new Label();
  
   // 分页变量
   static int pageSize = 10; // 要显示的页数
   static int totalPages = 0; // 总页数
   static int currentPage = 0; // 当前页
   static string firstVisibleCustomer = ""; // 当前页的第一条记录,用来进行移动“前一页”的定位。
   static string lastVisibleCustomer = ""; //当前页的最后条记录,用来进行移动“下一页”的定位。
  
   // DataSet用来绑定到DataGrid.
   static DataTable custTable;
  
   //初始化连接和DataAdapter.
   static SqlConnection nwindConn = new SqlConnection("Data Source=.;Integrated Security=SSPI;Initial Catalog=northwind");
   static SqlDataAdapter custDA = new SqlDataAdapter("", nwindConn);
   static SqlCommand selCmd = custDA.SelectCommand;
  
 

[1] [2] [3] 下一页

【责编:Peng】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·WEB程序开发--ASP.NET和PHP、JSP究竟学哪个?
 ·五步带你入门XML
 ·关于Java框架技术专题
 ·XML全攻略技术专题
 ·JAVA开源技术介绍专题
 ·Java嵌入式开发之J2ME技术专题
 ·超前体验 Oracle 11g的5个新特性…
 ·揭密使用VB.NET的五个实用技巧
 ·Oracle和SQL Server常用函数对比专题…
 ·展现C#世界 C#程序设计专题…
 今日更新
 社区讨论
 博客论点
 频道精选
 Dotnet频道相关导航