SqlServer 常用分页方法总结

SqlServer 常用分页方法总结

下面示例总结了,SqlServer数据库 常用分页方法,仅供学习参考

A、 使用 RowNumber 和 Between And 组合分页:

/********** 使用 RowNumber 和 Between And 组合分页 **********/
CREATE PROC proc_FuzzySearchAndPaging
@pageIndex int,           --页索引
@pageSize int,            --页大小
@SearchKey Nvarchar(10),  --查询关键字
@TotalCount int OutPut    --总数据条数
AS
  BEGIN
       --查询 当前页 数据
       SELECT * FROM(
           SELECT *,[NO]=ROW_NUMBER() OVER(ORDER BY s.s_id DESC) FROM StuInfo s
                  WHERE s.s_name Like('%'[email protected]+'%')
       ) t
       WHERE t.[NO] BETWEEN @pageSize*(@pageIndex-1)+1 AND @pageIndex*@pageSize
       ORDER BY t.s_id DESC

       --总数据条数
       SELECT @TotalCount = COUNT(*) FROM StuInfo s WHERE s.s_name Like('%'[email protected]+'%')
  END
GO

B、使用 TOP 和 NOT IN 组合分页:

/********** 使用 TOP 和 NOT IN 组合分页 **********/
CREATE PROC proc_FuzzySearchAndPaging2
@PageIndex int,             --当前页索引
@PageSize int,              --每页显示的数据条数
@FuzzyKey Nvarchar(20),     --模糊匹配的关键字
@Count int OUTPUT           --总数据条数(用来判断要分多少页)
AS
  BEGIN
      SELECT TOP(@PageSize) * FROM StuInfo s
			  WHERE s.s_name LIKE('%'[email protected]+'%')
			  AND s.s_id NOT IN(
			      SELECT TOP((@PageIndex-1)*@PageSize) s.s_id FROM StuInfo s
			             WHERE s.s_name LIKE('%'[email protected]+'%')
			             ORDER BY s.s_id ASC
			  )
			  ORDER BY s.s_id ASC

     --总数据条数
     SELECT @Count=COUNT(*) FROM StuInfo s WHERE s.s_name LIKE('%'[email protected]+'%')
  END
GO

如有,更好方法 方法欢迎拿出来分享!

扩充:分页时,可以充分借助 临时表 和  WITH AS 语句提供查询速度

WITH AS语句示例:

DECLARE @SearchKey Nvarchar(10)  --查询关键字
WITH t AS(
      SELECT * FROM StuInfo s
             WHERE s.s_name Like('%'[email protected]+'%')
)

临时表 语句示例:

DECLARE @SearchKey Nvarchar(10)  --查询关键字
SELECT * INTO #temp2 FROM (
       SELECT * FROM StuInfo s WHERE s.s_name Like('%'[email protected]+'%')
) u

SqlServer 常用分页方法总结,布布扣,bubuko.com

时间: 2024-10-25 07:55:55

SqlServer 常用分页方法总结的相关文章

SqlServer 经常使用分页方法总结

SqlServer 经常使用分页方法总结 以下演示样例总结了,SqlServer数据库 经常使用分页方法,仅供学习參考 A. 使用 RowNumber 和 Between And 组合分页: /********** 使用 RowNumber 和 Between And 组合分页 **********/ CREATE PROC proc_FuzzySearchAndPaging @pageIndex int, --页索引 @pageSize int, --页大小 @SearchKey Nvarch

mybatis常用经典分页方法

来自棱镜学院-在线IT教育www.prismcollege.com 分页方法一: 可以查看如下代码,新建一个数据库分页基础类 package com.ssm.utils.pagination.pagebounds; import java.util.List; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spr

SqlServer分页方法

/// <summary> /// 使用虚拟表进行分页查询,不适用明确知道列名的查询 /// </summary> /// <param name="sql">sql 如"select * from name where 1=1"</param> /// <param name="pageIndex">页码 如"1"</param> /// <par

ETL流程概述及常用实现方法

http://blog.csdn.net/btkuangxp/article/details/48224187 目录(?)[-] 1抽取作业 1手工开发抽取作业时候的常用方法 11当数据源和DW为同一类数据库时 12当数据源和ODS为不同类型数据库时 2更新数据的时间和数量的问题 21实时抽取数据 22批量抽取数据 221常用实现 222根据下载时候对数据的筛选方式可以分为 2转换作业 1数据清洗 2数据转换 3加载作业 4流程控制 5常用商业ETL工具 ETL是英文Extract-Transf

Oracle、MySql、SQLServer 数据分页查询

Oracle.MySql.SQLServer 数据分页查询 摘自:http://www.cnblogs.com/wangyong/p/3396333.html 近简单的对oracle,mysql,sqlserver2005的数据分页查询作了研究,把各自的查询的语句贴出来供大家学习..... (一). mysql的分页查询 mysql的分页查询是最简单的,借助关键字limit即可实现查询,查询语句通式: /* * sql:可以是单表的查询语句,也可以是多表的联合查询语句 * firstIndex:

SQLite的常用的方法

在Android开发中SQLite起着很重要的作用,网上SQLite的教程有很多很多,不过那些教程大多数都讲得不是很全面.本人总结了一些SQLite的常用的方法,借着论坛的大赛,跟大家分享分享的. 一.SQLite的介绍 1.SQLite简介 SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入  式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了.它能够支持 Windows/Linux/Unix等等

VC的常用调试方法

前言 VS是非常强大的IDE,所以掌握VSVC的常用方法,将会使得我们找出问题解决问题事半功倍. 目录 VSVC的常用调试方法 前言 1. Watch窗口查看伪变量 2. 查看指针指向的一序列值 3. 内存泄露查找 4. 调试Release版本 5. 远程调试 6. 函数断点 7. 数据断点. 8. 代码执行时间 9. 格式化数据 10. 格式化内存 Watch窗口查看伪变量 按MSDN的介绍,伪变量就是用来查看特定信息的术语.例如当调用的API失败时,可以用GetLastError获取对应的错

NSDictionary的初始化和一些常用的方法总结

NSDictionary //初始化1. NSDictionary *dic11=[[NSDictionary alloc] initWithObjects:@[@"qwe",@"asd",@"zxc",@"qaz",@"wsx"] forKeys:@[@"111",@"222",@"333",@"444",@"555

LINQ常用扩展方法

下面的方法都是IEnumerable<T>的扩展方法: Average计算平均值: Min最小元素:Max最大元素:Sum元素总和: Count元素数量: Concat连接两个序列://Unoin all Contains序列是否包含指定元素: Distinct取得序列中的非重复元素: Except获得两个序列的差集: Intersect获得两个序列的交集: First取得序列第一个元素: Single取得序列的唯一一个元素,如果元素个数不是1个,则报错:!!!严谨的程序. FirstOrDe