zoukankan      html  css  js  c++  java
  • SqlServer分页方法

    /// <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;
    }

    其他分页方法百度上比较多。

  • 相关阅读:
    设计模式 设计原则 何为设计
    面向对象 多态
    两个简易的对拍程序
    各类有用的神奇网站
    乘法逆元
    树链剖分
    Markdown的用法
    vimrc 的配置
    luogu【P1144】最短路计数
    【娱乐】收录各种神奇知乎问答
  • 原文地址:https://www.cnblogs.com/aroundight/p/4873664.html
Copyright © 2011-2022 走看看