三种SQL分页语句
来源:互联网 发布:南京行知中学升学率 编辑:程序博客网 时间:2024/05/17 06:14
下文将为您介绍三种SQL分页语句写法,如果您也遇到过类似的问题,不妨一看,相信对您会有所启迪。
SQL分页操作是经常会遇到的,下面就将为您介绍三种SQL分页语句,供您参考,希望对您学习SQL分页能够有所帮助。
方法一(适用于 SQL Server 2000/2005)
SELECT TOP 页大小 *
FROM table1
WHERE id NOT IN
(
SELECT TOP 页大小*(页数-1) id FROM table1 ORDER BY id
)
ORDER BY id
方法二(适用于 SQL Server 2000/2005)
SELECT TOP 页大小 *
FROM table1
WHERE id >
(
SELECT ISNULL(MAX(id),0)
FROM
(
SELECT TOP 页大小*(页数-1) id FROM table1 ORDER BY id
) A
)
ORDER BY id
方法三(适用于 SQL Server 2005)
SELECT TOP 页大小 *
FROM
(
SELECT ROW_NUMBER() OVER (ORDER BY id) AS RowNumber,* FROM table1
) A
WHERE RowNumber > 页大小*(页数-1)
----------------------------------------------------------
/// <summary>
/// 将原始SQL语句改造成支持分页的SQL语句
/// </summary>
/// <param name="sql">原始sql语句</param>
/// <param name="page">第几页</param>
/// <param name="pageSize">每页多少记录</param>
/// <param name="primaryField">原始sql语句主键字段</param>
/// <returns></returns>
string GetPageSql(string sql, int page, int pageSize,string primaryField)
{
StringBuilder pageSQL = new StringBuilder();
pageSQL.Append(string.Format ("SELECT TOP {0} * From ",pageSize ));
pageSQL.Append(" ( ");
pageSQL.Append(string.Format (" SELECT ROW_NUMBER() OVER (ORDER BY {0}) AS RowNumber,* FROM ",primaryField ));
pageSQL.Append(string.Format("({0}) tempTable1", sql));
pageSQL.Append(" ) tempTable2 ");
pageSQL.Append(string.Format(" WHERE RowNumber > {0}*({1}-1) ",pageSize , page));
return pageSQL.ToString();
}
- 三种SQL分页语句
- 三种SQL分页语句
- 三种SQL分页语句
- 三种高效率SQL语句分页方法
- 三种高效率SQL语句分页方法
- 三种SQL分页查询语句
- SQL分页语句三方案
- oracle分页三种SQL语句效率对比
- sql分页查询语句(三种主流数据库)
- sql分页查询语句(三种主流数据库)
- 三大数据库分页sql语句
- 四种SQL分页语句
- 三种SQL分页法
- 三种SQL分页法
- 三种SQL分页法
- 三种SQL分页法
- 三种SQL分页法
- 三种SQL分页法
- seam2.2根据已有数据库(postgresql)生成项目
- UploadDialog使用完整代码
- C#和Java中的一些不同
- mac组播
- 文件监控 Linux Windows
- 三种SQL分页语句
- Linux中硬链接文件和软链接文件的区别
- android 4.2以上版本永不休眠
- mysql的索引类型及优化
- python3 xml.dom.pulldom 解析xml
- A Game Between Alice and Bob(zoj 3529)
- 25个必须记住的SSH命令
- Protel DXP 2004安装 - Windows XP经典软件系列
- 类的组合问题