分页的sql语句_自动分页
下文将为您介绍三种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(); }
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/179166.html原文链接:https://javaforall.cn
相关文章
- SQL开发知识:关于表oracle的一些特殊查询sql语句
- Oracle删除表: 使用SQL语句(oracle删除表sql)
- MySQL 建表SQL精选实例(mysql建表sql)
- 语句MySQL 创建表:使用SQL语句实现.(mysql创建表sql)
- Oracle中的SQL语句学习指南(oracle的sql语句)
- tuningMySQL 日志分析指南:SQL 优化最佳实践(mysql日志sql)
- MongoDB实现“SQL NoSQL”合一(mongodb支持sql)
- 如何在MySQL中修改SQL语句?(mysql修改sql语句)
- MySQL学习笔记:创建表的SQL语句(mysql创建表的sql)
- 清空MySQL表的Effortless SQL语句(mysql清空表sql)
- 如何在Linux上导入SQL文件:操作简单易学(linux导入sql文件)
- SQL Server表排序:花式排列数据增强读取效率(sqlserver表排序)
- SQL数据同步MySQL的详细步骤和注意事项(sql同步mysql)
- SQL Server中的序列:自动生成独特值(sqlserver中序列)
- Oracle SQL跟踪神器——高效追踪SQL语句的工具(oracle跟踪sql工具)
- 学习MySQL使用SQL语句的技巧(mysql sql语句)
- 如何利用Oracle掌握SQL写作技巧(oracle写sql格式)
- MySQL 中 SQL 比较详解常用语句及其实现方法(mysql中sql比较)
- Oracle如何利用SQL快速写出时间表达式(oracle写时间sql)
- MySQL查询父子级关系的SQL语句(mysql 上下级sql)
- 如何创建Oracle SQL账号(oracle sql账号)
- 间空间技术提升 Oracle SQL 性能(oracle sql 空)
- Oracle 64位SQL助力数据库优化管理(oracle64位sql)
- t-sql/mssql用命令行导入数据脚本的SQL语句示例