对于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:42
  • 2307

winform自定义分页

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

Winform分页控件使用详细介绍

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

winform分页控件

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

分享一个Winform下的分页控件

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

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

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

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

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

winform 很好用的分页控件带SQL数据库

  • 2016年04月30日 14:21
  • 218KB
  • 下载

Winform 通用分页控件实战篇(提供源码下载)

在Web中,以前写过相关的分页控件的实例教程,如: 分页控件 实战 Post篇 (包源码的)   在Winform中,分页有时候也是必不可少的一项,因此, 新手Mark一下有时候是必要的。   ...
  • cyq1162
  • cyq1162
  • 2016-11-23 12:14:08
  • 505

自定义winform分页控件

原文地址:http://www.cnblogs.com/nosnowwolf/archive/2008/07/22/1248796.html  效果如下:代码实现如下: Code highlighti...
  • wanglong7505
  • wanglong7505
  • 2010-01-15 11:59:00
  • 6558
收藏助手
不良信息举报
您举报文章:对于C#,WinForm,比较舒服的分页
举报原因:
原因补充:

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