一个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();
    }
 
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

MSSQL根据表名动态分页的存储过程以及C#.net调用使用

2012-07-06 19:44 MSSQL根据表名进行动态分页的sql存储过程: 该存储过程中操作的表需要设置主键,否则分页出错....   --动态按表名分页-- alter ...

ASP.NET+Ajax+JQuey+Json数据+存储过程实现无刷新分页

var pageIndex=1; //当前页码 var totalPage; //总页数 $(function () { $.ajax({ ur...

AspNetPager+ROW_NUMBER()的分页存储过程 【百万数据】

ROW_NUMBER()分页存储过程-SQL2005才支持set ANSI_NULLS ON set QUOTED_IDENTIFIER ON go -- ==============...

Ext.Net 1.x_Ext.Net.GridPanel之存储过程分页Sql版本

1.分页存储过程 ALTER procedure [dbo].[AspNetPage] @tblName varchar(1000), -- 表名 @...

存储过程分页 .NET

  • 2012-08-30 10:32
  • 21KB
  • 下载

asp.net(C#)海量数据表高效率分页算法(易懂,不使用存储过程)

前台代码片段如下(webform8.aspx): WebForm8

ASP.NET 存储过程分页

  • 2013-12-04 10:09
  • 1.42MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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