DataGridView使用自定义控件实现简单分页功能
本例子使用自定义控件方法实现,数据库使用的是SQL Server,实现过程如下:
1、新建一个自定义控件,命名为:PageControl。
2、PageControl代码如下:
public partial class PageControl : UserControl
{
//委托及事件
public delegate void BindPage(int pageSize, int pageIndex, out int totalCount);
public event BindPage BindPageEvent; //属性
public int PageSize { get; set; } = ; //每页显示记录数
public int PageIndex { get; set; } //页序号
public int TotalCount { get; set; } //总记录数 public int PageCount { get; set; } //总页数 public PageControl()
{
InitializeComponent(); //取消下划线
linkFirst.LinkBehavior = LinkBehavior.NeverUnderline;
linkPrev.LinkBehavior = LinkBehavior.NeverUnderline;
linkNext.LinkBehavior = LinkBehavior.NeverUnderline;
linkLast.LinkBehavior = LinkBehavior.NeverUnderline;
linkGo.LinkBehavior = LinkBehavior.NeverUnderline;
} /// <summary>
/// 设置页
/// </summary>
public void SetPage()
{
//总记录数
int totalCount = ;
BindPageEvent(PageSize, PageIndex + , out totalCount);
TotalCount = totalCount; //总页数
if (TotalCount % PageSize == )
PageCount = TotalCount / PageSize;
else
PageCount = TotalCount / PageSize + ; //当前页及总页数
txtCurrentPage.Text = (PageIndex + ).ToString();
lblTotalPage.Text = "共 " + PageCount.ToString() + " 页";
} /// <summary>
/// 首页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkFirst_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
PageIndex = ;
SetPage();
}
} /// <summary>
/// 上一页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkPrve_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
PageIndex--;
if (PageIndex < )
{
PageIndex = ;
}
SetPage();
}
} /// <summary>
/// 下一页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkNext_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
PageIndex++;
if (PageIndex > PageCount - )
{
PageIndex = PageCount - ;
}
SetPage();
}
} /// <summary>
/// 末页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkLast_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
PageIndex = PageCount - ;
SetPage();
}
} /// <summary>
/// 只能按0-9、Delete、Enter、Backspace键
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void txtSetPage_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 linkGo_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
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();
} /// <summary>
/// linkFirst鼠标移过颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkFirst_MouseMove(object sender, MouseEventArgs e)
{
linkFirst.LinkColor = Color.Red;
} /// <summary>
/// linkFirst鼠标离开颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkFirst_MouseLeave(object sender, EventArgs e)
{
linkFirst.LinkColor = Color.Black;
} /// <summary>
/// linkPrev鼠标移过颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkPrev_MouseMove(object sender, MouseEventArgs e)
{
linkPrev.LinkColor = Color.Red;
} /// <summary>
/// linkPrev鼠标离开颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkPrev_MouseLeave(object sender, EventArgs e)
{
linkPrev.LinkColor = Color.Black;
} /// <summary>
/// linkNext鼠标移过颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkNext_MouseMove(object sender, MouseEventArgs e)
{
linkNext.LinkColor = Color.Red;
} /// <summary>
/// linkNext鼠标离开颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkNext_MouseLeave(object sender, EventArgs e)
{
linkNext.LinkColor = Color.Black;
} /// <summary>
/// linkLast鼠标移过颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkLast_MouseMove(object sender, MouseEventArgs e)
{
linkLast.LinkColor = Color.Red;
} /// <summary>
/// linkLast鼠标离开颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkLast_MouseLeave(object sender, EventArgs e)
{
linkLast.LinkColor = Color.Black;
} /// <summary>
/// linkGo鼠标移过颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkGo_MouseMove(object sender, MouseEventArgs e)
{
linkGo.LinkColor = Color.Red;
} /// <summary>
/// linkGo鼠标离开颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkGo_MouseLeave(object sender, EventArgs e)
{
linkGo.LinkColor = Color.Black;
}
}
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、新建一个WinForm程序,命名为Main,并拖入一个DataGridView控件及上面新建的PageControl控件,代码如下:
private void Main_Load(object sender, EventArgs e)
{
pageControl1.PageSize = ;
pageControl1.PageIndex = ;
pageControl1.BindPageEvent += BindPage;
pageControl1.SetPage();
} /// <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
}
5、执行程序:
好了,分享就到此结束了,希望对有此需要的人有一些帮助。
DataGridView使用自定义控件实现简单分页功能的更多相关文章
- DataGridView使用BindingNavigator实现简单分页功能
接上一篇<DataGridView使用自定义控件实现简单分页功能>,本篇使用BindingNavigator来实现简单分页功能.其实也只是借用了一个BindingNavigator空壳, ...
- jQuery实现的简单分页功能的详细解析
分页功能在项目开发中不可或缺,老司机操作起来就和呼吸一样简单,新手恐怕就会吃力一些. 今天我回顾了一下具体的操作步骤,决定详细的分析一下每一步的实现目的及原理. 我们会创建一个简单的json文件来模拟 ...
- Django实现简单分页功能
使用django的第三方模块django-pure-pagination 安装模块: pip install django-pure-pagination 将'pure_pagination'添加到s ...
- winform中DataGridView实现分页功能
WinForm轻松实现自定义分页 (转载) WinForm轻松实现自定义分页 (转载) 转载至http://xuzhihong1987.blog.163.com/blog/static/26731 ...
- 简单封装分页功能pageView.js
分页是一个很简单,通用的功能.作为一个有经验的前端开发人员,有义务把代码中类似这样公共的基础性的东西抽象出来,一来是改善代码的整体质量,更重要的是为了将来做类似的功能或者类似的项目,能减少不必要的重复 ...
- 利用Bootstrap Paginator插件和KnockoutJS完成分页功能
在最近一个项目中,需要结合一堆条件查询并对查询的结果数据完成一个简单分页功能,可是做着做着,自己的思路越来越模糊,做到心态崩溃!!! 哈哈,特此花点时间重新总结,并从最简单的分页,然后向多条件查询分页 ...
- MVC001之mvcpager简单分页
描述:用mvcpager实现简单分页功能 参考网址: http://www.cnblogs.com/iamlilinfeng/archive/2013/03/11/2951460.html http: ...
- C#设计模式总结 C#设计模式(22)——访问者模式(Vistor Pattern) C#设计模式总结 .NET Core launch.json 简介 利用Bootstrap Paginator插件和knockout.js完成分页功能 图片在线裁剪和图片上传总结 循序渐进学.Net Core Web Api开发系列【2】:利用Swagger调试WebApi
C#设计模式总结 一. 设计原则 使用设计模式的根本原因是适应变化,提高代码复用率,使软件更具有可维护性和可扩展性.并且,在进行设计的时候,也需要遵循以下几个原则:单一职责原则.开放封闭原则.里氏代替 ...
- php对文本文件进行分页功能简单实现
php对文本文件进行分页功能简单实现 <!DOCTYPE> <html> <head> <meta http-equiv="Content-type ...
随机推荐
- 【网络流相关】最大流的Dinic算法实现
Luogu P3376 于\(EK\)算法求最大流时每一次只求一条增广路,时间复杂度会比较高.尽管实际应用中表现比较优秀,但是有一些题目还是无法通过. 那么我们就会使用\(Dinic\)算法实现多路增 ...
- 2019-2020-1 20199304《Linux内核原理与分析》第五周作业
第四章 系统调用的三层机制(上) 4.1 用户态.内核态和中断 知识点总结: 与系统调用打交道的方式是通过库函数的方式. 用户态与内核态的区分 内核态:高的执行级别下,代码可以执行特权指令,访问任意的 ...
- docker镜像、docker容器导入导出命令
一.docker镜像导入导出命令 导出命令: docker save -o <保存路径> <镜像名称:标签> docker save -o ./test.tar test:la ...
- Flask开发天气查询软件,带你掌握pipenv的使用与手机Termux下的部署
关于pipenv 昨天介绍了pipenv这个相比于virtualenv更高端大气上档次的虚拟环境管理软件,但看了下流量貌似不是很受欢迎,也许是我介绍的不够好吧.那么今天就拿它做一个例子,开发一款天气预 ...
- 一招教你如何修复MySQL slave中继日志损坏问题
[摘要]MySQL的Crash safe slave是指slave crash后,把slave重新拉起来可以继续从Master进行复制,不会出现复制错误也不会出现数据不一致. PS:华为云数据库特惠专 ...
- replace find join
>>> s='spam' >>> s=s.replace('m','111') >>> s 'spa111' >>> where ...
- SX1276/SX1278和SXSX1262的详细参数对比
SX1276/SX1278和SX1262的对比 SX1262是Semtech公司新推出的一款sub-GHz无线收发器.SX1262芯片最大的买点是它的低功耗和超远距离的传输.SX1262接收电流 ...
- mac office软件的安装与破解
1.mac office 软件的安装及破解 http://10176523.cn/archives/29/ 下载后安装 切记不要登录 然后用这个文件 破解
- 带你从头到尾捋一遍MySQL索引结构(2)
前言 Hello我又来了,快年底了,作为一个有抱负的码农,我想给自己攒一个年终总结.索性这次把数据库中最核心的也是最难搞懂的内容,也就是索引,分享给大家. 这篇博客我会谈谈对于索引结构我自己的看法,以 ...
- [TimLinux] MySQL 中的CASE/WHEN语法
1. 介绍章节 MySQL 5.7-en.a4.pdf文档的第12章:Functions and Operators中的12.4Control Flow Functions介绍了流控制操作符:CASE ...