对于C#,WinForm,比较舒服的分页

原创 2017年03月29日 16:59:23

碰到需要分页的工作了,不让往Sql服务器上写存储过程,而且数据库字段也没有连续好用的列,那么问题来了,怎样才能舒坦的分页呢?


主要用到 

ROW_NUMBER() over (order by AgentID desc) rows1

 思路如下:


1.把数据全部缓存到本地,然后在本地实现分页----不到两秒 Pass~(Boss会打死我!)

2.在服务器上写存储过程,-----Pass(Boss不允许!)

3.直接用 BetWeen 关键字,但是这样分出来的数据可能会乱!(每次查询向后走一百条,支取需要的10条,这只是一个假分页!)

4.视图啊!MsSql中的视图啊!,详解如下: 


1.窗体运行的时候检测数据库中需要的视图是否存在,不存在则创建。

 public bool ExistView()  //判断视图是否存在
        {
            string sql = "select count(*) from sysobjects where xtype='V' and name='StoreMainView' ";
            if (int.Parse(DB.Dbs.Retstr(sql)) > 0)
            {

                return true;
            }
            else
            {
                return false;
            }
        }
        public void CreateView()  //不存在则创建
        {
            string sql = "create view [MainView] as select ROW_NUMBER() over (order by AgentID desc) rows1  , *  from [QcAps_StoreMain]";
            SqlCommand comm = new SqlCommand();
            comm.CommandText = sql;
            DB.Dbs.RetCount(comm);
        }

创建完成视图之后,我们就可以用多出来的那一列【rows1】 来进行查询(做视图的根本就是为了有一个连续的列进行分页)

  public DataTable SelectView(int Start, int End)
        {
            string sql = string.Format("SELECT  [BankBranch] as '开户支行'  FROM [StoreMainView] WHERE [StoreID] between {0} and {1}", Start, End);
            return DB.Dbs.RetDt(sql);
        }

使用起来是这样的:

   private int PageCount = 0;//一共有多少页
        private int PageRows = 21; //一页有多少行
        private int RowsStart = 0;//起始行数
        private int RowsEnd = 0;//终止行数
        private int Inum = 0;//当前页数
        private int state = 0;  //1 = 代理主表,2 = 代理员工表 , 3 = 店铺表
        private void Empty()
        {
            PageCount = 0;
            PageRows = 21;
            RowsStart = 0;
            RowsEnd = 0;
            Inum = 0;
            PageSub.Enabled = true;
            PageAdd.Enabled = true;
        }  //清空分页数据
        private void AgentMainPage()
        {
            Empty();
            state = 1;
            int count = agentmain.GetAllCount();
            PageCount = count / PageRows;
            if (PageCount < 1)
            {
                PageCount = 1;
            }
            RowsEnd = RowsStart + PageRows;
            PubList.DataSource = agentmain.SelectView(RowsStart, RowsEnd);
            Inum++;
        }   //初始化分页






版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u013542549/article/details/68067041

WinForm轻松实现自定义分页

以前都是做web开发,最近接触了下WinForm,发现WinForm分页控件好像都没有,网上搜索了一下,发现有很多网友写的分页控件,分页效果应该都能实现吧,只是其风格都不是很符合我想要的。做web的时...
  • nishiayan
  • nishiayan
  • 2015年07月06日 14:27
  • 2301

winform自定义分页

使用bindingNavigator和bindingSource1自定义分页组件,实现分页 /// /// 委托 /// /// /// public ...
  • sky08050025
  • sky08050025
  • 2017年01月05日 17:14
  • 917

winform分页的制作

成品效果: 下面是效果实现的所有代码: 备注: 控件名称解释: 首页(按钮)-->btnHomePage 上一页(按钮)-->btnUpPage 1(按钮)-->btnShowYe...
  • duoduoluojia
  • duoduoluojia
  • 2015年03月28日 13:14
  • 246

Winform分页控件使用详细介绍

Winform分页控件使用详细介绍 自从上篇随笔《Winform分页控件最新版本发布,并提供基于DotNetBar界面的版本》介绍了最新版本的分页控件,并提供下载使用后,很多人对分页控件...
  • weinierbian
  • weinierbian
  • 2012年05月08日 08:36
  • 6370

winform分页控件

  • 2010年08月11日 16:43
  • 8KB
  • 下载

分享一个Winform下的分页控件

分享一个Winform下的分页控件。如有反馈,请联系邀月。3w@live.cn
  • downmoon
  • downmoon
  • 2011年02月10日 15:51
  • 16172

C# WinForm 技巧一: 自定义分页控件

老罗传奇 快乐高效的生活 LCL https://github.com/luomingui 首页新随笔订阅管理 随笔 - 215  文章 - 21  评论 - 113 ...
  • kasama1953
  • kasama1953
  • 2016年08月05日 22:28
  • 5037

WinForm下编写分页控件,实现DataGridView的分页效果

     前几天做C/S项目的时候用到了分页查询,所以就想去网上找一些封装好的分页控件,类似BS项目中的那种。但是找了好几个都不是特别的好,没有自己想要的。而且WinForm 里面的Da...
  • u010028869
  • u010028869
  • 2014年09月27日 22:18
  • 11424

分享一个Winform下的分页控件

分享一个Winform下的分页控件 前两天有一个简单的C/S项目用到分页,因为是Winform下,没有现成的,自己也懒得写,就找了下,看到了ycmoon的一个控件 http://w...
  • u014180504
  • u014180504
  • 2014年12月16日 14:14
  • 1033

WinForm下编写分页控件,实现DataGridView的分页效果

  • 2014年09月27日 22:15
  • 187KB
  • 下载
收藏助手
不良信息举报
您举报文章:对于C#,WinForm,比较舒服的分页
举报原因:
原因补充:

(最多只允许输入30个字)