大数量查询分页显示

原创 2007年09月28日 13:48:00
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());
}
}  

easyui-datagrid使用load()保持分页显示数量

easyui snippet 2017-6-20 14:41:26 我之前用easyui-datagrid都是使用的下面这种方法加载数据,查询按钮就是再调一次这个方法。这样做有个小问题,就是...
  • lich1n
  • lich1n
  • 2017年06月20日 14:52
  • 89

Web开发——获取查询内容(内容分页显示)【前台页面部分】

代码实现功能描述:根据用户在页面上输入的开始时间和结束时间,从数据库中获取数据,获取的数据以每页10条的格式分页显示在页面上。 Document .rptIntfPortl...
  • MOONCOM
  • MOONCOM
  • 2017年06月28日 19:06
  • 382

数据库查询结果分页显示思路

数据库查询结果分页显示思路,通过计算Result Set指针位置实现分页显示//设置页面显示数量 int pageSize; //获取要显示页面 int currentPage; //需要定义的参数...

qt 数据库查询结构的分页显示

QT界面中实现数据库查询结果的分页显示 昨天做的,今天整理了下。 数据库依然使用的是MySQL。固定每页显示的条数,然后通过SQL语句的limit属性控制查询出的结果条数。然后显示在页面上...
  • csweier
  • csweier
  • 2012年12月03日 16:22
  • 5891

【ASP】对数据库查询的内容分页显示算法的改进

上次写的《【ASP】数据库查询的内容分页显示》(点击打开链接)中的实现算法虽然能够在一个特定的表中实现了预想的效果, 但是这一算法移植到其他系统之后,发现通用性不强 首先此分页算法的具体实施是通过...

JSP分页,查询结果分页显示

原文地址:http://wenku.baidu.com/view/fe2933e79b89680203d825b5.html

php数据库查询分页显示操作(一)

PHP数据库查询分页显示操作(一) 在网站后台开发过程中,必不可少的就是与数据库连接进行Create、Update、Retrieve、Delete操作。在信息表显示操作的时候,就会用到分页技术。 ...

JSP通用查询处理与分页显示

JSP通用查询处理与分页显示   铁树 tieshu    2006年4月2日星期日   (注:涉及的源码可通过Email:rngguliu@163.com获取) 1 基本思想 ...

前台jsp获取后台查询的结果集数据并实现分页显示

前台获取后台查询的结果并分页显示。 1、使用ajax异步请求,发送post请求到url,获取结果参数data(data被dao层处理成json对象返回) 2、返回的结果: 在da...

实现分页显示数据[并按关键字查询]

前面的文章实现了分页显示,现在把分页显示的进行了整合,整合到了一个单独的页面中,加入了按关键字查询,具体实现如下: 用于实现分页和查询的页面文件: split_page_plugin.jsp ...
  • cselmu9
  • cselmu9
  • 2012年08月01日 20:15
  • 3817
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:大数量查询分页显示
举报原因:
原因补充:

(最多只允许输入30个字)