【开源】QuickPager ASP.NET2.0分页控件V2.0.0.6 修改了几个小bug,使用演示。

本文介绍了一种能在同一页面上对SQL Server 2000、SQL Server 2005、Access及Excel等多种数据库进行分页显示的方法。通过配置不同的数据访问函数库实例,实现了对不同数据库的支持。

 

     由于项目里面还在使用vs2003,还没有使用新的分页控件,所以对新的分页控件的测试还很不到位,遗留了不少的bug,感谢网友试用提出宝贵意见。由于项目正在收尾中,时间也不是太充裕,所以使用说明也不够详细。这次是发一个新的版本,另外主要是说一下,如何在一个页面(一个项目)里访问多种数据库,对多种数据库里的表进行分页。

 

     我用过的数据库有SQL Server2000、SQL Server2005、Access、Excel,而分页控件也支持这四种数据库,那么就以这四种数据库为例。目的是在一个页面里面对这四种数据库里的表进行分页显示。

 

     如何在项目里添加控件,请看这里:http://www.cnblogs.com/jyk/archive/2008/06/27/1231337.html

 

     目前分页控件里面的分页算法有

     

     // 基于Row_Number的分页算法,只支持SQL Server2005数据库
     Row_Number = 1,

     

     // 基于表变量的分页算法,支持SQL Server2000、SQL Server2005数据库
     TableVar = 2,

 

     // Max的分页算法。支持SQL Server2000、SQL Server2005数据库
     MaxMin = 3,

 

     // 颠倒法,需要设置主键,已经修改了最后一页的bug。支持SQL Server2000、SQL Server2005、Access、Excel
     TopTop = 4,

 

     // Max 和 颠倒法自动切换
     Max_TopTop = 304,

 

     // Max 和 表变量自动切换
     Max_TableVar = 302

 

     数据库就用 northwind 吧,这个大家都有吧。拿一个简单的表Products来分页吧。

 

     1、在页面里拖拽四个GridView控件,和四个分页控件,一一对应,每一组对应一种数据库。

 

     2、由于数据库的类型不一样,所以每一个分页控件都需要不同的数据访问函数库的实例。由于web.confog里面的连接字符串是访问SQL Server2000的,所以SQL Server2000对应的分页控件就不用单独设置了,其他的三个分页控件需要单独设置一下数据访问函数库的实例。(代码在下面一起给出)

     

     3、数据访问函数库的实例设置完毕之后其他的设置就没有特殊的地方了,和访问一种数据库是一样的,只是对于Excel文件来说,表名是工作表 + “$”组成的。比如工作表的名称是“Sheet1”,那么对应的表名是“Sheet1$”。

 

     4、代码:

 

 

 1 protected   void  Page_Load( object  sender, EventArgs e)
 2 ExpandedBlockStart.gifContractedBlock.gif     {
 3        Response.Cache.SetNoStore();
 4
 5ContractedSubBlock.gifExpandedSubBlockStart.gif        设置SQL 2005的分页控件需要的数据访问函数库的实例#region 设置SQL 2005的分页控件需要的数据访问函数库的实例
 6        //连接字符串
 7        string cnStr = @"Data Source=.\s05;Initial Catalog=northwind ;persist security info=False;user id=sa;pwd=admin;";
 8
 9        //定义数据访问函数库
10        DataAccessHelp dal_2005 = new DataAccessHelp("1", cnStr);
11        //交给给分页控件
12        this.myPager_2005.DAL = dal_2005;
13        #endregion

14
15ContractedSubBlock.gifExpandedSubBlockStart.gif        设置Access的分页控件需要的数据访问函数库的实例#region 设置Access的分页控件需要的数据访问函数库的实例
16        //连接字符串
17        string Path = Server.MapPath("~/dataAccess.mdb");
18        cnStr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Path + ";Jet OLEDB:Database Locking Mode=1;";
19
20        //定义数据访问函数库
21        DataAccessHelp dal_Access = new DataAccessHelp("2", cnStr);
22        //交给给分页控件
23        myPager_Access.DAL = dal_Access;
24        #endregion

25
26ContractedSubBlock.gifExpandedSubBlockStart.gif        设置Excel的分页控件需要的数据访问函数库的实例#region 设置Excel的分页控件需要的数据访问函数库的实例
27        //连接字符串
28        Path = Server.MapPath("~/dataExcel.xls");
29        cnStr = "Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source =" + Path + ";Extended Properties=Excel 8.0";//;HDR=YES;
30
31        //定义数据访问函数库
32        DataAccessHelp dal_Excel = new DataAccessHelp("2", cnStr);
33        //交给给分页控件
34        this.myPager_Excel.DAL = dal_Excel;
35        #endregion

36
37
38        if (!Page.IsPostBack)
39ExpandedSubBlockStart.gifContractedSubBlock.gif        {
40            setPageInfo1();
41            setPageInfo2();
42            setPageInfo3();
43            setPageInfo4();
44        }

45    }

46
47 ContractedBlock.gifExpandedBlockStart.gif     设置分页控件的属性 sql 2000 #region 设置分页控件的属性 sql 2000 
48    private void setPageInfo1()
49ExpandedSubBlockStart.gifContractedSubBlock.gif    {
50        //以下三个属性必须赋值
51        this.myPager_2000.ControlGridID = this.GV_2000.ID;
52
53        this.myPager_2000.TableName = " Products";      //表名或者视图名
54        this.myPager_2000.TableIDColumns = "ProductID";       //主键
55        this.myPager_2000.TableShowColumns = "*";    //显示的字段,可以不填,默认为 *
56        this.myPager_2000.TableOrderColumns = "ProductName,ProductID ";  //排序字段,可以写多个字段
57        this.myPager_2000.TableQuery = "";           //查询条件,不包含 where 
58         
59        this.myPager_2000.PageSize = 3;              //一页显示的记录数,默认一页显示20条记录
60        this.myPager_2000.NaviCount = 8;             //页号导航的数量,默认10个
61
62
63    }

64    #endregion

 

     其他数据库的设置方法也是一样的,省略了。下面的网址有完全的代码。     

 

     5、分页控件的源码和demo的下载网址:http://www.cnblogs.com/jyk/archive/2008/07/29/1255891.html

 

 

转载于:https://www.cnblogs.com/jyk/archive/2008/07/30/1256816.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值