对于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++;
        }   //初始化分页






版权声明:本文为博主原创文章,未经博主允许不得转载。

WinForm轻松实现自定义分页

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

winform自定义分页

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

Winform分页控件使用详细介绍

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

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

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

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

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

C# WinForm DataGridView 分页程序

今天搜集到一些代码,很有用,保存,留作日后再用 //导入命名空间部分省略 DBClass.DBExecute dbexecute = new DBExecute(); ...
  • zhaowenkaiyongheng
  • zhaowenkaiyongheng
  • 2016年11月29日 14:37
  • 558

C#入门学习-----选项卡(更改显示样式、动态添加/删除、获得名称)

欢迎大家提出意见,一起讨论! 转载请标明是引用于 http://blog.csdn.net/chenyujing1234 需要源码请与我联系。   运行效果如下: 1、更改显选项卡的显示...
  • chenyujing1234
  • chenyujing1234
  • 2012年06月05日 16:59
  • 18722

C# WinForm 分页控件以及Demo演示(存储过程,有脚本)超级简单的,你值得拥有

  • 2017年07月11日 10:47
  • 102KB
  • 下载

winfrom分页控件

  • 2012年06月05日 15:47
  • 46KB
  • 下载

分享一个Winform下的分页控件

分享一个Winform下的分页控件。如有反馈,请联系邀月。3w@live.cn
  • downmoon
  • downmoon
  • 2011年02月10日 15:51
  • 16053
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:对于C#,WinForm,比较舒服的分页
举报原因:
原因补充:

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