大数量查询分页显示

16 篇文章 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());
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
查询结果分页显示可以通过以下步骤实现: 1. 前端页面设计 在查询结果页面中,添加分页导航栏,包含上一页、下一页、首页、尾页等按钮,以及页码显示区域。 ```html <div class="pagination"> <button id="first-page">首页</button> <button id="prev-page">上一页</button> <span id="page-info"></span> <button id="next-page">下一页</button> <button id="last-page">尾页</button> </div> ``` 2. 后端实现分页查询 在后端实现分页查询功能,可以使用 SQL 语句的 `LIMIT` 子句来限制查询结果的数量和起始位置。 例如,使用 MySQL 数据库: ```sql SELECT * FROM users LIMIT 10 OFFSET 0; ``` 表示查询 users 表中从第 1 行开始的 10 行数据。 3. 前端发送分页请求 在前端页面中,使用 Ajax 发送分页请求,请求后端返回当前页的数据。同时,更新分页导航栏的状态,包括页码、按钮状态等。 ```javascript function loadPage(page) { $.get('/users', {page: page}, function(data) { // 更新页面数据 renderPage(data); // 更新分页导航栏 updatePagination(page, data.totalPages); }); } ``` 4. 前端更新页面数据 前端接收到后端返回的分页数据后,根据数据更新页面的显示内容。 ```javascript function renderPage(data) { var users = data.users; // 清空用户列表 $('#user-list').empty(); // 循环添加用户 for (var i = 0; i < users.length; i++) { var user = users[i]; var html = '<tr><td>' + user.id + '</td><td>' + user.username + '</td><td>' + user.email + '</td></tr>'; $('#user-list').append(html); } } ``` 5. 前端更新分页导航栏 前端接收到后端返回的分页数据后,根据数据更新分页导航栏的状态。 ```javascript function updatePagination(currentPage, totalPages) { // 更新页码显示 $('#page-info').text('第 ' + currentPage + ' 页,共 ' + totalPages + ' 页'); // 更新按钮状态 if (currentPage === 1) { $('#first-page').prop('disabled', true); $('#prev-page').prop('disabled', true); } else { $('#first-page').prop('disabled', false); $('#prev-page').prop('disabled', false); } if (currentPage === totalPages) { $('#next-page').prop('disabled', true); $('#last-page').prop('disabled', true); } else { $('#next-page').prop('disabled', false); $('#last-page').prop('disabled', false); } } ``` 通过以上步骤,就可以实现查询结果分页显示
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值