科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道C#通过查询结果进行分页 1

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

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

  通过查询结果进行分页就是以结果集的子集处理查询结果的过程,这样,每次返回给用户的只是当前页面的数据大小

作者:中国IT实验室 来源:中国IT实验室 2007年9月10日

关键字: 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; 
   
 

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章