SqlServer分頁方法

來源:互聯網
上載者:User

標籤:

/// <summary>/// 使用虛擬表進行分頁查詢,不適用明確知道列名的查詢/// </summary>/// <param name="sql">sql 如"select * from name where 1=1"</param>/// <param name="pageIndex">頁碼 如"1"</param>/// <param name="pageSize">條數 如"100"</param>/// <returns>DataTable</returns>public static DataTable SelectPaging(String sql, int pageIndex, int pageSize){    //定義虛擬表名稱    string temporaryTable = "#" + randString();    //建立您虛擬表    string sqlPaging = "select identity(int) as ZZZZZ, * into " + temporaryTable + " from (select TOP 100 Percent * from ( " + sql + ") a) a ";    //使用虛擬表進行分頁查詢    sqlPaging += "select * from " + temporaryTable + " a WHERE 1=1 "        + "AND a.ZZZZZ >= " + pageIndex * pageSize + " AND a.ZZZZZ <= " + ((pageIndex + 1) * pageSize - 1) + " ";    //刪除虛擬表    sqlPaging += "DROP TABLE " + temporaryTable;    //執行Sql語句 SelectCustomSql為執行sql的方法需自己定義    DataTable dt = SelectCustomSql(sqlPaging);    //判斷返回結果是否為空白    if (dt != null)    {        //移除識別欄位        dt.Columns.Remove("ZZZZZ");    }    //返回結果    return dt;}

其他分頁方法百度上比較多。

SqlServer分頁方法

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.