日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > C# >内容正文

C#

[C#学习] DataAdapter.Fill()分页

發布時間:2025/3/8 C# 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [C#学习] DataAdapter.Fill()分页 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

查詢結果分頁是以較小數據子集(即頁)的形式返回查詢結果的過程。 它通常用于以易于管理的小塊形式向用戶顯示結果。

DataAdapter 提供了通過 Fill 方法的重載來僅返回一頁數據的功能。 但是,對于大量的查詢結果,它可能并不是首選的分頁方法,因為 DataAdapter 雖然僅使用所請求的記錄來填充目標 DataTable 或 DataSet,但仍會使用返回整個查詢的資源。 若要在從數據源中返回一頁數據時不使用返回整個查詢的資源,請為查詢指定附加條件,使返回的行數減少到只返回所需的行。

若要使用 Fill 方法返回一頁數據,請指定 startRecord 參數(代表該數據頁中的第一個記錄),并指定 maxRecords 參數(代表該數據頁中的記錄數)。

以下代碼示例顯示如何使用 Fill 方法來返回查詢結果(頁大小為 5 個記錄)的第一頁。

int currentIndex = 0;

int pageSize = 5;

string orderSQL = ”SELECT * FROM Orders ORDER BY OrderID”;
// Assumes that connection is a valid SqlConnection object.
SqlDataAdapter adapter = new SqlDataAdapter(orderSQL, connection);

DataSet dataSet = new DataSet();
adapter.Fill(dataSet, currentIndex, pageSize, ”Orders”);

在上例中,DataSet 只填充了 5 個記錄,但卻返回了整個 Orders 表。 若要用相同的 5 個記錄填充 DataSet 但僅返回這 5 個記錄,請在 SQL 語句中使用 TOP 和 WHERE 子句,如以下代碼示例所示。

int pageSize = 5;

string orderSQL = ”SELECT TOP ” + pageSize +
“ * FROM Orders ORDER BY OrderID”;
SqlDataAdapter adapter = new SqlDataAdapter(orderSQL, connection);

DataSet dataSet = new DataSet();
adapter.Fill(dataSet, ”Orders”);

請注意,當以這種方式進行查詢結果分頁時,必須保留用于對行進行排序的唯一標識符,以便將唯一 ID 傳遞給用于返回下一頁記錄的命令,如以下代碼示例所示。

string lastRecord =

dataSet.Tables["Orders"].Rows[pageSize - 1]["OrderID"].ToString();

若要使用接受 startRecord 和 maxRecords 參數的 Fill 方法的重載來返回下一頁記錄,請使當前記錄索引按頁大小遞增,并填充該表。 請記住,即使僅在 DataSet 中添加一頁記錄,數據庫服務器仍會返回全部查詢結果。 在以下代碼示例中,先清除表行,然后再用下一頁數據填充這些表行。 您可能需要在本地緩存中保留一定數量的返回行,以減少與數據庫服務器的往返次數。

currentIndex += pageSize;

dataSet.Tables["Orders"].Rows.Clear();

adapter.Fill(dataSet, currentIndex, pageSize, ”Orders”);

若要返回下一頁記錄而不讓數據庫服務器返回整個查詢,請指定對 SQL SELECT 語句的限制條件。 由于上例保留了返回的最后一個記錄,因此可以在 WHERE 子句中使用它來指定查詢的起點,如以下代碼示例所示。

orderSQL = ”SELECT TOP ” + pageSize +

“ * FROM Orders WHERE OrderID > ” + lastRecord + ” ORDER BY OrderID”;
adapter.SelectCommand.CommandText = orderSQL;

dataSet.Tables["Orders"].Rows.Clear();

adapter.Fill(dataSet, ”Orders”);

轉載于:https://www.cnblogs.com/AngryZe/p/8280376.html

總結

以上是生活随笔為你收集整理的[C#学习] DataAdapter.Fill()分页的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。