大数量查询分页显示 微软的解决办法

所属分类: 网络编程 / ASP编程 阅读数: 1301
收藏 0 赞 0 分享
微软的解决办法
using System; 
using System.Data; 
using System.Data.SqlClient; 
using System.Drawing; 
using System.Windows.Forms; 

public class PagingSample: Form 

// Form controls. 
Button prevBtn = new Button(); 
Button nextBtn = new Button(); 

static DataGrid myGrid = new DataGrid(); 
static Label pageLbl = new Label(); 

// Paging variables. 
static int pageSize = 10; // Size of viewed page. 
static int totalPages = 0; // Total pages. 
static int currentPage = 0; // Current page. 
static string firstVisibleCustomer = ""; // First customer on page to determine location for move previous. 
static string lastVisibleCustomer = ""; // Last customer on page to determine location for move next. 

// DataSet to bind to DataGrid. 
static DataTable custTable; 

// Initialize connection to database and DataAdapter. 
static SqlConnection nwindConn = new SqlConnection("Data Source=localhost;Integrated Security=SSPI;Initial Catalog=northwind"); 
static SqlDataAdapter custDA = new SqlDataAdapter("", nwindConn); 
static SqlCommand selCmd = custDA.SelectCommand; 

public static void GetData(string direction) 

// Create SQL statement to return a page of records. 
selCmd.Parameters.Clear(); 

switch (direction) 

case "Next": 
selCmd.CommandText = "SELECT TOP " + pageSize + " CustomerID, CompanyName FROM Customers " + 
"WHERE CustomerID > @CustomerId ORDER BY CustomerID"; 
selCmd.Parameters.Add("@CustomerId", SqlDbType.VarChar, 5).Value = lastVisibleCustomer; 
break; 
case "Previous": 
selCmd.CommandText = "SELECT TOP " + pageSize + " CustomerID, CompanyName FROM Customers " + 
"WHERE CustomerID < @CustomerId ORDER BY CustomerID DESC"; 
selCmd.Parameters.Add("@CustomerId", SqlDbType.VarChar, 5).Value = firstVisibleCustomer; 
break; 
default: 
selCmd.CommandText = "SELECT TOP " + pageSize + " CustomerID, CompanyName FROM Customers ORDER BY CustomerID"; 

// Determine total pages. 
SqlCommand totCMD = new SqlCommand("SELECT Count(*) FROM Customers", nwindConn); 
nwindConn.Open(); 
int totalRecords = (int)totCMD.ExecuteScalar(); 
nwindConn.Close(); 
totalPages = (int)Math.Ceiling((double)totalRecords / pageSize); 

break; 


// Fill a temporary table with query results. 
DataTable tmpTable = new DataTable("Customers"); 
int recordsAffected = custDA.Fill(tmpTable); 

// If table does not exist, create it. 
if (custTable == null) 
custTable = tmpTable.Clone(); 

// Refresh table if at least one record returned. 
if (recordsAffected > 0) 

switch (direction) 

case "Next": 
currentPage++; 
break; 
case "Previous": 
currentPage--; 
break; 
default: 
currentPage = 1; 
break; 


pageLbl.Text = "Page " + currentPage + " of " + totalPages; 

// Clear rows and add new results. 
custTable.Rows.Clear(); 

foreach (DataRow myRow in tmpTable.Rows) 
custTable.ImportRow(myRow); 

// Preserve first and last primary key values. 
DataRow[] ordRows = custTable.Select("", "CustomerID ASC"); 
firstVisibleCustomer = ordRows[0][0].ToString(); 
lastVisibleCustomer = ordRows[custTable.Rows.Count - 1][0].ToString(); 





public PagingSample() 

// Initialize controls and add to form. 
this.ClientSize = new Size(360, 274); 
this.Text = "NorthWind Data"; 

myGrid.Location = new Point(10,10); 
myGrid.Size = new Size(340, 220); 
myGrid.AllowSorting = true; 
myGrid.CaptionText = "NorthWind Customers"; 
myGrid.ReadOnly = true; 
myGrid.AllowNavigation = false; 
myGrid.PreferredColumnWidth = 150; 

prevBtn.Text = "<<"; 
prevBtn.Size = new Size(48, 24); 
prevBtn.Location = new Point(92, 240); 
prevBtn.Click += new EventHandler(Prev_OnClick); 

nextBtn.Text = ">>"; 
nextBtn.Size = new Size(48, 24); 
nextBtn.Location = new Point(160, 240); 

pageLbl.Text = "No Records Returned."; 
pageLbl.Size = new Size(130, 16); 
pageLbl.Location = new Point(218, 244); 

this.Controls.Add(myGrid); 
this.Controls.Add(prevBtn); 
this.Controls.Add(nextBtn); 
this.Controls.Add(pageLbl); 
nextBtn.Click += new EventHandler(Next_OnClick); 


// Populate DataSet with first page of records and bind to grid. 
GetData("Default"); 
DataView custDV = new DataView(custTable, "", "CustomerID", DataViewRowState.CurrentRows); 
myGrid.SetDataBinding(custDV, ""); 




public static void Prev_OnClick(object sender, EventArgs args) 

GetData("Previous"); 


public static void Next_OnClick(object sender, EventArgs args) 

GetData("Next"); 





public class Sample 

static void Main() 

Application.Run(new PagingSample()); 

更多精彩内容其他人还在看

asp知识整理笔记4(问答模式)

这是关于asp知识整理的最后一份笔记,希望大家仔细阅读。
收藏 0 赞 0 分享

ASP基础知识VBScript基本元素讲解

这篇文章主要介绍了ASP基础知识VBScript基本元素的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

ASP编码和解码函数详解

这篇文章主要介绍了ASP编码和解码函数的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

ASP显示页面执行时间的方法

这篇文章主要介绍了ASP显示页面执行时间的方法,在本地测试一下输出页面需要多少时间,需要的朋友可以参考下
收藏 0 赞 0 分享

ASP基础入门第一篇(ASP技术简介)

本文将以 Active Server Pages 为中心,向你全面展示制作动态商业网站的步骤和技巧并通过大量的实例,让你在不断的理论和实践之中笑傲“网络”……
收藏 0 赞 0 分享

ASP基础入门第二篇(ASP基础知识)

这篇文章是ASP基础入门第二篇,第一篇展示了ASP动态网站设计的一些最基本的方法,相信通过实践各位对 ASP 已经有了最基本的了解,本文将进一步介绍ASP动态网站的一些基本技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

ASP基础入门第三篇(ASP脚本基础)

通过前两篇的学习,相信各位已经对 ASP 的动态网站设计有了一个基本的概念和整体的印象。从本篇开始作者将从脚本语言的使用着手,由浅入深地带领大家探索 ASP 动态网站设计的真正奥秘。
收藏 0 赞 0 分享

ASP基础入门第四篇(脚本变量、函数、过程和条件语句)

大家在学习了脚本语言 VBScript 的变量、常量和过程的基本概念后,本期将继续向各位介绍 VBScript 的函数和语法。
收藏 0 赞 0 分享

ASP基础入门第五篇(ASP脚本循环语句)

在本文上两篇中,我们学习了脚本语言 VBScript 的变量、函数、过程和条件语句,本篇将继续给大家介绍 VBScipt 的循环语句,并对脚本语言在 ASP 中的应用加以总结。  
收藏 0 赞 0 分享

ASP基础入门第六篇(ASP内建对象Request)

从本篇开始作者从 ASP 内建对象着手,为大家详细剖析 ASP 的六个内建对象和各种组件的特性和方法,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多