一个c#.net存储过程版本的分页,支持百万数据分页

原创 2007年09月19日 13:56:00
protected void dataBind() {

        int page = 1;

        if (Request.QueryString["page"] != null){
            page = Convert.ToInt32(Request["page"]);
        }

        if (Request.Form["page"] != null){
            page = Convert.ToInt32(Request.Form["page"]);
        }

        int myPageSize = 20;

        SqlConnection conn = new SqlConnection(dbTool.myConnStr);

        SqlCommand cmd = new SqlCommand("p_page", conn);
        cmd.CommandType = CommandType.StoredProcedure;

        cmd.Parameters.Add("@Tables", SqlDbType.VarChar, 50);
        cmd.Parameters["@Tables"].Value = "testTable";

        cmd.Parameters.Add("@PrimaryKey", SqlDbType.VarChar, 50);
        cmd.Parameters["@PrimaryKey"].Value = "id";

        cmd.Parameters.Add("@Sort", SqlDbType.VarChar, 50);
        cmd.Parameters["@Sort"].Value = "id asc";

        cmd.Parameters.Add("@CurrentPage", SqlDbType.Int, 4);
        cmd.Parameters["@CurrentPage"].Value = page;

        cmd.Parameters.Add("@PageSize", SqlDbType.Int, 4);
        cmd.Parameters["@PageSize"].Value = myPageSize;

        cmd.Parameters.Add("@Fields", SqlDbType.VarChar, 50);
        cmd.Parameters["@Fields"].Value = "id,username";

        cmd.Parameters.Add("@Filter", SqlDbType.VarChar, 50);
        cmd.Parameters["@Filter"].Value = "id>1000 and id<10000";

        cmd.Parameters.Add("@Group", SqlDbType.VarChar, 50);
        cmd.Parameters["@Group"].Value = "";

        cmd.Parameters.Add("@TotalPage", SqlDbType.Int, 4);
        cmd.Parameters["@TotalPage"].Direction = ParameterDirection.Output;

        cmd.Parameters.Add("@TotalRecord", SqlDbType.Int, 4);
        cmd.Parameters["@TotalRecord"].Direction = ParameterDirection.ReturnValue;

        conn.Open();

        //先取得返回值
        cmd.ExecuteNonQuery();
        int totalPage, totalRecord;
        totalPage = Convert.ToInt32(cmd.Parameters["@TotalPage"].Value);
        totalRecord = Convert.ToInt32(cmd.Parameters["@totalRecord"].Value);


        //再取得返回记录集
        SqlDataReader sdr = cmd.ExecuteReader();
        GridView1.DataSource = sdr;
        GridView1.DataBind();

        cmd.Dispose();
        conn.Dispose();

        tools mytool = new tools(Response, Request);
        
              /*
         * 功能:PageLink显示分页导航
         * totalCount:总记录数        
         * totalPage:总页数
         * Page:页码
         * PerPageSize:每页显示记录数
         * GroupSizes:每组分页显示的页码数
         * PageArgu:分页参数
         * ShowGoto:是否显示跳转
         */

        lblPageLink.Text = mytool.PageLink(totalRecord, totalPage, page, myPageSize, 3, "page",true);
       
        mytool.Dispose();
    }
 

oracle百万级数据分页优化

oracle count 百万级 分页查询记录总数、总条数优化 oracle count 百万级 查询记录总数、总条数优化  最近做一个项目时,做分页时,发现分页查询速度很慢,分页我做的是...
  • li5311263
  • li5311263
  • 2016年01月15日 09:48
  • 1730

MySQL 百万级分页优化(Mysql千万级快速分页)

一般刚开始学SQL的时候,会这样写 SELECT * FROM table ORDER BY id LIMIT 1000, 10; 但在数据达到百万级的时候,这样写会慢死 SELECT * FR...
  • li772030428
  • li772030428
  • 2016年10月17日 16:59
  • 2957

MySQL 百万级分页优化(Mysql千万级快速分页)

MySQL 百万级分页优化(Mysql千万级快速分页) 以下分享一点我的经验  一般刚开始学SQL的时候,会这样写  复制代码代码如下: SELECT * ...
  • a724888
  • a724888
  • 2017年03月08日 19:21
  • 1269

MySQL处理千万级数据查询、分页

MySQL数据库优化处理实现千万级快速分页分析,来看下吧。 数据表 collect ( id, title ,info ,vtype) 就这4个字段,其中 title 用定长,info 用tex...
  • educast
  • educast
  • 2015年05月08日 14:23
  • 8264

Sybase 海量数据分页瞬间完成

海量数据分页(100W条),首次分页大概为10秒左右。以后翻页基本上是瞬间完成。要求是无排序情况下。 目前sybase分页: 1,hibernate分页:hibernate分页前几页和后几页没问题,如...
  • damenggege123
  • damenggege123
  • 2013年04月22日 10:15
  • 5085

如何用extjs实现海量数据的快速分页显示

点击查询按钮,会查询出N万条数据。  后台java方法会把查询出的这N万条数据,以JSON格式传送给前台。  代码如:  view plain  JSONObject obje...
  • qiufeng1989916
  • qiufeng1989916
  • 2014年03月18日 16:46
  • 980

【C#】真分页功能的实现

【前言】         分页功能是非常常见的,在一般的项目中或多或少都会出现需要将数据库中的信息查询出来展示到前台的功能,但是为了用户体验度往往需要分页显示这些数据。 【实现】        我们在...
  • zh15732621679
  • zh15732621679
  • 2017年02月18日 23:01
  • 1434

c#导出数据至excel模板中,可分页

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.R...
  • sky1989ss
  • sky1989ss
  • 2016年09月13日 14:54
  • 2172

前端开发-数据分页请求和删除

最近更新时间:2017年5月31日14:57:09     做前端开发的过程中,将服务器数据展现出来是常见的业务需求,这个过程中需要用到分页处理方案。本文研究的实际案例是,移动端展示用户收藏的列表项...
  • wanshaobo888
  • wanshaobo888
  • 2017年05月31日 17:54
  • 445

分享一个完整的Mybatis分页解决方案

原文地址:http://duanhengbin.iteye.com/blog/1998017 参考地址:http://blog.csdn.net/isea533/article/details/23...
  • xiyang_1990
  • xiyang_1990
  • 2017年01月14日 23:40
  • 703
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:一个c#.net存储过程版本的分页,支持百万数据分页
举报原因:
原因补充:

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