DataGridView使用BindingNavigator實現(xiàn)簡單分頁功能
上篇文章給大家介紹DataGridView使用自定義控件實現(xiàn)簡單分頁功能,本篇使用BindingNavigator來實現(xiàn)簡單分頁功能。其實也只是借用了一個BindingNavigator空殼,
實現(xiàn)原理和代碼與上一篇幾乎一樣,實現(xiàn)方法如下:
1、新建一個WinForm程序,命名為BindingNavigatorMain,并拖入一個DataGridView控件及一個BindingNavigator控件。在BindingNavigator右下角彈窗中添加
一個Button(轉到),BindingNavigator的樣式如下:

2、BindingNavigatorMain的代碼如下:
private int pageSize; //每頁顯示記錄數(shù)
private int pageIndex; //頁序號
private int totalCount; //總記錄數(shù)
private int pageCount; //總頁數(shù)
public BindingNavigatorMain()
{
InitializeComponent();
}
private void BindingNavigatorMain_Load(object sender, EventArgs e)
{
pageSize = 20;
pageIndex = 0;
SetPage();
}
//設置頁
private void SetPage()
{
//總記錄數(shù)
totalCount = 0;
BindPage(pageSize, pageIndex + 1, out totalCount);
//總頁數(shù)
if (totalCount % pageSize == 0)
pageCount = totalCount / pageSize;
else
pageCount = totalCount / pageSize + 1;
//當前頁及總頁數(shù)
txtCurrentPage.Text = (pageIndex + 1).ToString();
lblTotalPage.Text = "共 " + pageCount.ToString() + " 頁";
//BindingNavigator數(shù)據(jù)源不進行BindingSource賦值,但恢復控件可用性。
bindingNavigatorMoveFirstItem.Enabled = true;
bindingNavigatorMovePreviousItem.Enabled = true;
txtCurrentPage.Enabled = true;
lblTotalPage.Enabled = true;
bindingNavigatorMoveNextItem.Enabled = true;
bindingNavigatorMoveLastItem.Enabled = true;
}
/// <summary>
/// 綁定頁
/// </summary>
/// <param name="pageSize">每頁顯示記錄數(shù)</param>
/// <param name="pageIndex">頁序號</param>
/// <param name="totalCount">總記錄數(shù)</param>
private void BindPage(int pageSize, int pageIndex, out int totalCount)
{
SqlConnection conn = null;
SqlCommand cmd = null;
totalCount = 0;
#region 連接數(shù)據(jù)庫測試
try
{
//數(shù)據(jù)庫連接
conn = new SqlConnection("server=.;database=DB_TEST;Uid=sa;pwd=********;");
conn.Open();
//SqlCommand
cmd = new SqlCommand();
cmd.Connection = conn;
cmd.CommandText = "PageTest";
cmd.CommandType = CommandType.StoredProcedure;
SqlParameter[] param =
{
new SqlParameter("@PageSize",SqlDbType.Int),
new SqlParameter("@PageIndex",SqlDbType.Int),
new SqlParameter("@TotalCount",SqlDbType.Int)
};
param[0].Value = pageSize;
param[1].Value = pageIndex;
param[2].Direction = ParameterDirection.Output;
cmd.Parameters.AddRange(param);
//DataTable
DataTable dt = new DataTable("MF_MO");
dt.Columns.Add(new DataColumn("MO_NO", typeof(String)));
dt.Columns.Add(new DataColumn("MRP_NO", typeof(String)));
dt.Columns.Add(new DataColumn("QTY", typeof(Decimal)));
dt.Columns.Add(new DataColumn("BIL_NO", typeof(String)));
#region 方法一:SqlDataReader
SqlDataReader dr = cmd.ExecuteReader();
dt.Load(dr, LoadOption.PreserveChanges);
dr.Close();
totalCount = (int)param[2].Value;
dataGridView1.DataSource = dt;
#endregion
#region #方法二:SqlDataAdapter
//SqlDataAdapter da = new SqlDataAdapter();
//da.SelectCommand = cmd;
//dt.BeginLoadData();
//da.Fill(dt);
//dt.EndLoadData();
//totalCount = (int)param[2].Value;
//dataGridView1.DataSource = dt;
#endregion
}
catch (Exception ex)
{
MessageBox.Show(ex.Message, "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
finally
{
conn.Close();
cmd.Dispose();
}
#endregion
}
/// <summary>
/// 首頁
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void bindingNavigatorMoveFirstItem_Click(object sender, EventArgs e)
{
pageIndex = 0;
SetPage();
}
/// <summary>
/// 上一頁
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void bindingNavigatorMovePreviousItem_Click(object sender, EventArgs e)
{
pageIndex--;
if (pageIndex < 0)
{
pageIndex = 0;
}
SetPage();
}
/// <summary>
/// 下一頁
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void bindingNavigatorMoveNextItem_Click(object sender, EventArgs e)
{
pageIndex++;
if (pageIndex > pageCount - 1)
{
pageIndex = pageCount - 1;
}
SetPage();
}
/// <summary>
/// 末頁
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void bindingNavigatorMoveLastItem_Click(object sender, EventArgs e)
{
pageIndex = pageCount - 1;
SetPage();
}
/// <summary>
/// 只能按0-9、Delete、Enter、Backspace鍵
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void txtCurrentPage_KeyPress(object sender, KeyPressEventArgs e)
{
if ((e.KeyChar >= 48 && e.KeyChar <= 57) || e.KeyChar == 8 || e.KeyChar == 13 || e.KeyChar == 127)
{
e.Handled = false;
if (e.KeyChar == 13)
{
Go();
}
}
else
{
e.Handled = true;
}
}
/// <summary>
/// 指定頁
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnGo_Click(object sender, EventArgs e)
{
Go();
}
private void Go()
{
if (string.IsNullOrEmpty(txtCurrentPage.Text))
{
MessageBox.Show("指定頁不能為空。", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
txtCurrentPage.Focus();
return;
}
if (int.Parse(txtCurrentPage.Text) > pageCount)
{
MessageBox.Show("指定頁已超過總頁數(shù)。", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
txtCurrentPage.Focus();
return;
}
pageIndex = int.Parse(txtCurrentPage.Text) - 1;
SetPage();
}
3、SQL Server創(chuàng)建存儲過程PageTest:
CREATE PROCEDURE [dbo].[PageTest]
@PageSize INT,
@PageIndex INT,
@TotalCount INT OUTPUT
AS
BEGIN
--總記錄數(shù)
SELECT @TotalCount=COUNT(1) FROM MF_MO
--記錄返回(使用動態(tài)SQL繞開參數(shù)嗅探問題,效率大幅度提升。)
DECLARE @SQL NVARCHAR(1000)
SET @SQL=
'SELECT TOP ('+CONVERT(VARCHAR(32),@PageSize)+') MO_NO,MRP_NO,QTY,BIL_NO '+
'FROM MF_MO A '+
'WHERE NOT EXISTS (SELECT 1 FROM (SELECT TOP ('+CONVERT(VARCHAR(32),(@PageIndex-1)*@PageSize)+') MO_NO FROM MF_MO ORDER BY MO_NO) B WHERE A.MO_NO=B.MO_NO) '+
'ORDER BY MO_NO'
EXEC (@SQL)
END
4、執(zhí)行程序:

好了,分享就到此結束了,希望對有此需要的人有一些幫助。
總結
以上所述是小編給大家介紹的DataGridView使用BindingNavigator實現(xiàn)簡單分頁功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!
相關文章
在 .NET Framework 2.0 中未處理的異常導致基于 ASP.NET 的應用程序意外退出
如果在 Microsoft .NET Framework 2.0 上構建的基于 Microsoft ASP.NET 的應用程序中引發(fā)未處理的異常,該應用程序將會意外退出。如果出現(xiàn)這個問題,不會在應用程序日志中記錄了解此問題所必需的異常信息。2009-11-11
ASP.NET實現(xiàn)數(shù)據(jù)的添加(第10節(jié))
這篇文章主要介紹了ASP.NET如何實現(xiàn)數(shù)據(jù)的添加,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2015-08-08
c# 操作符?? null coalescing operator
?? "null coalescing" operator 是c#新提供的一個操作符,這個操作符提供的功能是判斷左側的操作數(shù)是否是null,如果是則返回結果是右側的操作數(shù);非null則返回左側的操作數(shù)。2009-06-06
AspNetPager分頁控件源代碼(Version 4.2)
AspNetPager分頁控件源代碼(Version 4.2)...2007-04-04
asp net core2.1如何使用jwt從原理到精通(二)
這篇文章主要給大家介紹了關于asp net core2.1如何使用jwt從原理到精通的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-11-11
asp.net(c#)限制用戶輸入規(guī)定的字符和數(shù)字的代碼
這幾天在看到一個網(wǎng)站的注冊的時候,就只允許輸入規(guī)定的字符和數(shù)字。我就好奇的寫了一個校驗的代碼。呵呵 不知道對大家有沒有用。如果有用的話可以保存。沒有用就當是看看以下了。2010-10-10
.NET從優(yōu)酷專輯中采集所有視頻及信息(VB.NET代碼)
因為想做一個視頻點播類的網(wǎng)站,所以開始研究視頻采集。2010-02-02

