MS SqlServer 2005 分页处理
来源:互联网 发布:上药控股 知乎 编辑:程序博客网 时间:2024/05/18 21:42
SQL2005增加了不少新特性,其中NTILE和ROW_NUMER使得我们不再为SQL如何灵活方便的分页伤脑筋了(不必再羡慕Oracle等数据库了)。
下面就是一个很简单的分页查询语句: DECLARE @rows_per_page AS INTEGER
DECLARE @current_page AS INTEGER
DECLARE @total_pages AS INTEGER
-- 设置每页的行数
SET @rows_per_page = 20
-- 设置要显示的页号(从1开始)
SET @current_page = 2
-- 计算总页数
SELECT @total_pages = COUNT(*) / @rows_per_page
FROM testtable;
-- 列出指定页的内容
WITH t AS
(
SELECT NTILE(@total_pages) OVER(ORDER BY id) AS page_number, *
FROM testtable
)
SELECT * from t
WHERE page_number = @current_page 程序简单到可以不用说明的程度。
我们可以利用上述简单的语句,变化排序条件和查询表,就可以做出一个很通用的分页查询的存储过程或查询语句了。
同样的,使用ROW_NUMBER也可以做到分页查询: DECLARE @rows_per_page AS INTEGER
DECLARE @current_page AS INTEGER
DECLARE @start_row_num AS INTEGER
-- 设置每页的行数
SET @rows_per_page = 20
-- 设置要显示的页号(从1开始)
SET @current_page = 2
-- 设置开始行号
SET @start_row_num = (@current_page - 1) * @rows_per_page
WITH t AS
(
SELECT ROW_NUMBER() OVER(ORDER BY id) AS row_number, *
FROM testtable
)
SELECT * from t
WHERE row_number BETWEEN @start_row_num AND @start_row_num + @rows_per_page 似乎更简单的样子。
- MS SqlServer 2005 分页处理
- 数据库分页语句(ms sqlserver)
- MS SQLSERVER通用存储过程分页
- MS SQLSERVER通用存储过程分页
- maven+ssm+sqlserver分页处理
- 在MS SQLServer中使用存储过程实现通用分页
- MS SqlServer海量数据分页存储过程收集
- sqlserver 2005 分页查询
- MS SQLServer 2008数据库处于SUSPECT情况下的处理
- php pdo sqlserver分页sql的处理
- sqlserver分页几种处理办法
- Ms sqlserver 2005 数据库远程备份
- Android连接MS SQLServer 数据库2005-2014
- MS SQL Server 2005 分页存储过程
- MS SQL Server 2005 分页存储过程
- JdbcTemplate + sqlserver 2005 分页+Extjs
- MS SQLServer 资源链接
- MS SQLServer Trigger
- ORACLE 时间日期操作
- [zz]目前国内p2p视频直播软件
- 《Windows CE嵌入式开发入门——基于Xscale架构》目录
- mssql 导出数据成 insert into 语句
- PDA开发经验小结
- MS SqlServer 2005 分页处理
- 高密度光滑透明材质
- 关于PChar和指针
- IDispatch的作用
- tcl/tk safe - 1 - interp基本命令
- 读服务器上的文件和读本地的文件
- ASP.NET获取客户端IP及MAC地址
- net计算时间差
- U-Boot源代码阅读笔记(三) —— 对board.c的分析