热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

大数量查询分页显示微软的解决办法
微软的解决办法
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()); 


推荐阅读
  • PHP组合工具以及开发所需的工具
    本文介绍了PHP开发中常用的组合工具和开发所需的工具。对于数据分析软件,包括Excel、hihidata、SPSS、SAS、MARLAB、Eview以及各种BI与报表工具等。同时还介绍了PHP开发所需的PHP MySQL Apache集成环境,包括推荐的AppServ等版本。 ... [详细]
  • 本文介绍了在Win10上安装WinPythonHadoop的详细步骤,包括安装Python环境、安装JDK8、安装pyspark、安装Hadoop和Spark、设置环境变量、下载winutils.exe等。同时提醒注意Hadoop版本与pyspark版本的一致性,并建议重启电脑以确保安装成功。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文讨论了在数据库打开和关闭状态下,重新命名或移动数据文件和日志文件的情况。针对性能和维护原因,需要将数据库文件移动到不同的磁盘上或重新分配到新的磁盘上的情况,以及在操作系统级别移动或重命名数据文件但未在数据库层进行重命名导致报错的情况。通过三个方面进行讨论。 ... [详细]
  • 全面介绍Windows内存管理机制及C++内存分配实例(四):内存映射文件
    本文旨在全面介绍Windows内存管理机制及C++内存分配实例中的内存映射文件。通过对内存映射文件的使用场合和与虚拟内存的区别进行解析,帮助读者更好地理解操作系统的内存管理机制。同时,本文还提供了相关章节的链接,方便读者深入学习Windows内存管理及C++内存分配实例的其他内容。 ... [详细]
  • Linux环境变量$PATH的作用及使用方法
    本文介绍了Linux环境变量$PATH的作用及使用方法。$PATH是一个由多个目录组成的变量,用冒号分隔。当执行一个指令时,系统会按照$PATH定义的目录顺序搜索同名的可执行文件,如果有多个同名指令,则先找到的会被执行。通过设置$PATH变量,可以在任何地方执行指令,无需输入绝对路径。 ... [详细]
  • Windows7企业版怎样存储安全新功能详解
    本文介绍了电脑公司发布的GHOST WIN7 SP1 X64 通用特别版 V2019.12,软件大小为5.71 GB,支持简体中文,属于国产软件,免费使用。文章还提到了用户评分和软件分类为Win7系统,运行环境为Windows。同时,文章还介绍了平台检测结果,无插件,通过了360、腾讯、金山和瑞星的检测。此外,文章还提到了本地下载文件大小为5.71 GB,需要先下载高速下载器才能进行高速下载。最后,文章详细解释了Windows7企业版的存储安全新功能。 ... [详细]
  • asp中如何嵌入python的简单介绍
    本文目录一览:1、如何在IIS中执行Python脚本 ... [详细]
  • 你是否注意到,当你在高优先级下运行应用程序是,应用程序运行得特别快(这也视你运行什么样的应用程序而定)。拿WinRar做例子 ... [详细]
  • 翻译 | 编写SVG的口袋指南(上)
    作者:DDU(沪江前端开发工程师)本文是原文翻译,转载请注明作者及出处。简介ScalableVectorGraphics(SVG)是在XML中描述二维图形的语言。这些图形由路径,图 ... [详细]
  • Qt开发,出现一个提示:conversionfrom‘QSqlTableModel*’tonon-scalartype‘QSqlTableModel’requested代码: ... [详细]
  • 5.单例模式classMarker(valcolor:String){类中的任何代码段作为构造函数的一部分println(Creating+this)over ... [详细]
  • 动态分页实现
    Code分页存储过程CREATEprocedurePagersqlstrnvarchar(4000),--查询字符串currentpageint,--第N页pagesizeint- ... [详细]
  • 优酷如何去广告?优酷去广告方法
    优酷如何去广告?优酷应该是大家最常使用的视频播放器了,然而优酷的广告也是很多,那么要如何去除烦心的广告呢?下面小编给大家分享优酷去广告的小技巧,请大家笑纳!步骤如下:1、找到hos ... [详细]
author-avatar
荣清右
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有