接上一篇《DataGridView使用自定义控件实现简单分页功能》,本篇使用BindingNavigator来实现简单分页功能。其实也只是借用了一个BindingNavigator空壳,

实现原理和代码与上一篇几乎一样,实现方法如下:

 1、新建一个WinForm程序,命名为BindingNavigatorMain,并拖入一个DataGridView控件及一个BindingNavigator控件。在BindingNavigator右下角弹窗中添加

一个Button(转到),BindingNavigator的样式如下:

2、BindingNavigatorMain的代码如下:

        private int pageSize;   //每页显示记录数
private int pageIndex; //页序号
private int totalCount; //总记录数
private int pageCount; //总页数 public BindingNavigatorMain()
{
InitializeComponent();
} private void BindingNavigatorMain_Load(object sender, EventArgs e)
{
pageSize = ;
pageIndex = ;
SetPage();
} //设置页
private void SetPage()
{
//总记录数
totalCount = ;
BindPage(pageSize, pageIndex + , out totalCount); //总页数
if (totalCount % pageSize == )
pageCount = totalCount / pageSize;
else
pageCount = totalCount / pageSize + ; //当前页及总页数
txtCurrentPage.Text = (pageIndex + ).ToString();
lblTotalPage.Text = "共 " + pageCount.ToString() + " 页"; //BindingNavigator数据源不进行BindingSource赋值,但恢复控件可用性。
bindingNavigatorMoveFirstItem.Enabled = true;
bindingNavigatorMovePreviousItem.Enabled = true;
txtCurrentPage.Enabled = true;
lblTotalPage.Enabled = true;
bindingNavigatorMoveNextItem.Enabled = true;
bindingNavigatorMoveLastItem.Enabled = true;
} /// <summary>
/// 绑定页
/// </summary>
/// <param name="pageSize">每页显示记录数</param>
/// <param name="pageIndex">页序号</param>
/// <param name="totalCount">总记录数</param>
private void BindPage(int pageSize, int pageIndex, out int totalCount)
{
SqlConnection conn = null;
SqlCommand cmd = null;
totalCount = ; #region 连接数据库测试
try
{
//数据库连接
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[].Value = pageSize;
param[].Value = pageIndex;
param[].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[].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 = ;
SetPage();
} /// <summary>
/// 上一页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void bindingNavigatorMovePreviousItem_Click(object sender, EventArgs e)
{
pageIndex--;
if (pageIndex < )
{
pageIndex = ;
}
SetPage();
} /// <summary>
/// 下一页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void bindingNavigatorMoveNextItem_Click(object sender, EventArgs e)
{
pageIndex++;
if (pageIndex > pageCount - )
{
pageIndex = pageCount - ;
}
SetPage();
} /// <summary>
/// 末页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void bindingNavigatorMoveLastItem_Click(object sender, EventArgs e)
{
pageIndex = pageCount - ;
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 >= && e.KeyChar <= ) || e.KeyChar == || e.KeyChar == || e.KeyChar == )
{
e.Handled = false;
if (e.KeyChar == )
{
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("指定页已超过总页数。", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
txtCurrentPage.Focus();
return;
} pageIndex = int.Parse(txtCurrentPage.Text) - ;
SetPage();
}

3、SQL Server创建存储过程PageTest:

CREATE PROCEDURE [dbo].[PageTest]
@PageSize INT,
@PageIndex INT,
@TotalCount INT OUTPUT
AS
BEGIN
--总记录数
SELECT @TotalCount=COUNT(1) FROM MF_MO --记录返回(使用动态SQL绕开参数嗅探问题,效率大幅度提升。)
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、执行程序:

好了,分享就到此结束了,希望对有此需要的人有一些帮助。

DataGridView使用BindingNavigator实现简单分页功能的更多相关文章

  1. DataGridView使用自定义控件实现简单分页功能

    本例子使用自定义控件方法实现,数据库使用的是SQL Server,实现过程如下: 1.新建一个自定义控件,命名为:PageControl. 2.PageControl代码如下: public part ...

  2. jQuery实现的简单分页功能的详细解析

    分页功能在项目开发中不可或缺,老司机操作起来就和呼吸一样简单,新手恐怕就会吃力一些. 今天我回顾了一下具体的操作步骤,决定详细的分析一下每一步的实现目的及原理. 我们会创建一个简单的json文件来模拟 ...

  3. Django实现简单分页功能

    使用django的第三方模块django-pure-pagination 安装模块: pip install django-pure-pagination 将'pure_pagination'添加到s ...

  4. winform中DataGridView实现分页功能

    WinForm轻松实现自定义分页 (转载) WinForm轻松实现自定义分页 (转载)   转载至http://xuzhihong1987.blog.163.com/blog/static/26731 ...

  5. 简单封装分页功能pageView.js

    分页是一个很简单,通用的功能.作为一个有经验的前端开发人员,有义务把代码中类似这样公共的基础性的东西抽象出来,一来是改善代码的整体质量,更重要的是为了将来做类似的功能或者类似的项目,能减少不必要的重复 ...

  6. 利用Bootstrap Paginator插件和KnockoutJS完成分页功能

    在最近一个项目中,需要结合一堆条件查询并对查询的结果数据完成一个简单分页功能,可是做着做着,自己的思路越来越模糊,做到心态崩溃!!! 哈哈,特此花点时间重新总结,并从最简单的分页,然后向多条件查询分页 ...

  7. MVC001之mvcpager简单分页

    描述:用mvcpager实现简单分页功能 参考网址: http://www.cnblogs.com/iamlilinfeng/archive/2013/03/11/2951460.html http: ...

  8. C#设计模式总结 C#设计模式(22)——访问者模式(Vistor Pattern) C#设计模式总结 .NET Core launch.json 简介 利用Bootstrap Paginator插件和knockout.js完成分页功能 图片在线裁剪和图片上传总结 循序渐进学.Net Core Web Api开发系列【2】:利用Swagger调试WebApi

    C#设计模式总结 一. 设计原则 使用设计模式的根本原因是适应变化,提高代码复用率,使软件更具有可维护性和可扩展性.并且,在进行设计的时候,也需要遵循以下几个原则:单一职责原则.开放封闭原则.里氏代替 ...

  9. php对文本文件进行分页功能简单实现

    php对文本文件进行分页功能简单实现 <!DOCTYPE> <html> <head> <meta http-equiv="Content-type ...

随机推荐

  1. 2019-2020-1 20199304《Linux内核原理与分析》第四周作业

    第三章 MenuOs的构造 一.前情回顾 计算机的三大法宝: -存储程序计算机 -函数调用堆栈 -中断 操作系统的两把宝剑: -中断上下文的切换(保存现场和恢复现场) -进程上下文的切换 二.3.1 ...

  2. springcloud集成redis

    1.application.properties/application.yml配置: redis: # redis数据库索引(默认为0),我们使用索引为3的数据库,避免和其他数据库冲突 databa ...

  3. 掘金转载-手写一个Promise

    目录 一 什么是Promise ? 二 Promises/A+ 规范 2.1 术语 2.2 基本要求 2.2.1. Promise的状态 2.2.2. Then 方法 2.3 简易版实践 2.4 进一 ...

  4. 洛谷P2569 (BZOJ1855)[SCOI2010]股票交易 【单调队列优化DP】

    Description 最近lxhgww又迷上了投资股票,通过一段时间的观察和学习,他总结出了股票行情的一些规律. 通过一段时间的观察,lxhgww预测到了未来T天内某只股票的走势,第i天的股票买入价 ...

  5. ACM小组的古怪象棋

    Description ACM小组的Samsara和Staginner对中国象棋特别感兴趣,尤其对马(可能是因为这个棋子的走法比较多吧)的使用进行深入研究.今天他们又在 构思一个古怪的棋局:假如Sam ...

  6. MySQL 表记录查询小练习

    表记录查询小练习 查看岗位是teacher的员工姓名.年龄 查看岗位是teacher且年龄大于26岁的员工姓名.年龄 查看岗位是teacher且薪资在12000-16000范围内的员工姓名.年龄.薪资 ...

  7. 【HTTP】402- 深入理解http2.0协议,看这篇就够了!

    本文字数:3825字 预计阅读时间:20分钟 导读 http2.0是一种安全高效的下一代http传输协议.安全是因为http2.0建立在https协议的基础上,高效是因为它是通过二进制分帧来进行数据传 ...

  8. 【hibernate】常用注解

    [hibernate]常用注解 转载:https://www.cnblogs.com/yangchongxing/p/10357118.html 目录 ======================== ...

  9. 为什么我的tomcat启动不起来?

    现象: tomcat安装好了,准备部署Web项目了,启动tomcat,发现没有反应. 虽然显示了Tomcat started.但是这个 started不等同于 success,当我们打开浏览器访问80 ...

  10. Python3 基本类型在64位上的占用内存情况

    基本类型占用的内存 类型 # -*- coding: utf-8 -*- # @Time : 2019-12-19 11:16 # @Author : binger import sys a = No ...