一個c#.net預存程序版本的分頁,支援百萬資料分頁

來源:互聯網
上載者:User
因為有以前的CF、Javascript、Php及Asp的分頁基本,昨天拿著C#.net順心很多,其實也就是把CF中的代碼直接複製粘貼進Vs.net中,編寫了一個類也就OK了。

用起來挺順心。調用方式大致如下:

 程式碼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();
    }

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.