≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > SQL Server

SQL Server 支持定位当前页,自定义排序的分页SQL(拒绝动态SQL)

人气:517 时间:2019-05-14

这篇文章主要为大家详细介绍了SQL Server 支持定位当前页,自定义排序的分页SQL(拒绝动态SQL),具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!

1,场景:根据学生编号查询,返回该学生所在班级的所有学生。支持分页、自定义排序及结果集自动定位到查询条件的学生编号所在页。

代码如下:

 
CREATE PROC [dbo].[Sp_testpagerandsorting] (@GroupID INT, 
@CurrentId INT, 
@TimeFrom DATETIME, 
@TimeTo DATETIME, 
@OrderBy CHAR(50), 
@PageSize INT, 
@CurrentPage INT) 
AS 
SET nocount ON 
BEGIN 
DECLARE @StartNumber INT, 
@EndNumber INT, 
@CurrentIdRowNumber INT, 
@RecordCount INT, 
@EndPageIndex INT 
DECLARE @RowNumberTable TABLE ( 
rownumber INT IDENTITY (1, 1), 
id INT ) 
--step 1: Build sort id list ------------------------------------------------------- 
INSERT INTO @RowNumberTable 
(id) 
SELECT sm.id AS id 
FROM dbo.test sm WITH (nolock) 
WHERE indate BETWEEN Coalesce(@TimeFrom, indate) AND 
Coalesce(@TimeTo, indate) 
AND sm.groupid = @GroupID 
ORDER BY CASE 
WHEN @OrderBy = 'InDate desc' THEN ( Row_number() OVER (ORDER BY indate DESC)) 
WHEN @OrderBy = 'InDate asc' THEN (Row_number() OVER (ORDER BY indate ASC)) 
WHEN @OrderBy = 'Id asc' THEN (Row_number() OVER (ORDER BY sm.id ASC)) 
WHEN @OrderBy = 'Id desc' THEN (Row_number() OVER (ORDER BY sm.id DESC)) 
WHEN @OrderBy = 'Name asc' THEN (Row_number() OVER (ORDER BY sm.name ASC)) 
WHEN @OrderBy = 'Name desc' THEN (Row_number() OVER (ORDER BY sm.name DESC) ) 
END 
--step 2: Reset page index with current id ----------------------------------------- 
IF @CurrentIdNumber > 0 
BEGIN 
SELECT TOP 1 @CurrentIdRowNumber = rownumber 
FROM @RowNumberTable 
WHERE id = @CurrentIdNumber 
IF @CurrentIdRowNumber > 0 
BEGIN 
IF @CurrentPage = 0 
BEGIN 
SET @CurrentPage = Ceiling(CAST(@CurrentIdRowNumber AS DECIMAL) / CAST (@PageSize AS DECIMAL)) 
END 
END 
END 
ELSE 
BEGIN 
IF @CurrentPage = 0 
BEGIN 
SET @CurrentPage = 1 
END 
END 
--step 3: Set recordCount ----------------------------------------- 
SELECT @RecordCount = COUNT(1) 
FROM @RowNumberTable 
--step 4: Calc startNumber & endNumber ----------------------------------------- 
SELECT @StartNumber = @PageSize * ( @CurrentPage - 1 ), 
@EndNumber = @PageSize * ( @CurrentPage - 1 ) + @pageSize, 
@EndPageIndex = Ceiling(CAST(@RecordCount AS DECIMAL) / CAST(@PageSize AS DECIMAL)) 
IF @CurrentPage = @EndPageIndex 
BEGIN 
SET @EndNumber = @RecordCount 
END 
--step 5: Get sorted id of current page ----------------------------------------- 
;WITH a 
AS (SELECT TOP (@EndNumber - @StartNumber) id, 
rownumber 
FROM (SELECT TOP (@EndNumber) id, 
rownumber 
FROM @RowNumberTable) AS b 
ORDER BY rownumber DESC) 
--step 6: Return current page idList ------------------------------------------------------- 
SELECT [ID], 
[GroupID] [Name], 
[Address] 
FROM dbo.test sm WITH(nolock) 
INNER JOIN a 
ON a.id = sm.id 
ORDER BY a.rownumber 
-- step 7:return current page & record count ---------------------------------- 
SELECT @CurrentPage AS currentpage, 
@RecordCount AS recordcount 
END 

2,简单条件的,动态where语句(关于Like查询的动态where,建议使用笨办法做)

代码如下:

 
CREATE PROC [dbo].[Getstudentlistbycondition] @Name NVARCHAR(20), 
@Class INT 
AS 
SET nocount ON 
BEGIN 
BEGIN 
SELECT [Name], 
[class] 
FROM [testtable] 
WHERE [Class] = CASE 
WHEN @Class > 0 THEN @Class ELSE [Class] END 
AND [name] = CASE 
WHEN @Name <> '' THEN @Name ELSE [Name] END 
END 
END 

本文来自:http://www.q1010.com/179/7432-0.html

注:关于SQL Server 支持定位当前页,自定义排序的分页SQL(拒绝动态SQL)的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:SQL SERVER

您可能感兴趣的文章

  • 分页存储过程(二)在sqlserver中返回更加准确的分页结果
  • SQLServer上查看SQL语句的执行时间的方法
  • SQL Server 2000数据库同步 同步两个SQLServer数据库的内容
  • SQLServer触发器创建、删除、修改、查看示例代码
  • MMC提示不能打开文件SQLServerEnterpriseManager.MSC的解决方法
  • SQLServer 数据导入导出的几种方法小结
  • Sqlserver 存储过程中结合事务的代码
  • SQL SERVER 错误22022 SQLServerAgent当前未运行的解决方法
  • SQLServer的备份和灾难恢复
  • Sqlserver2000 数据库备份实例代码
上一篇:SQL Server sql 取两值之间的数据方法(例:100-200之间的数据)
下一篇:SQL Server下Kill 所有连接到某一数据库的连接
热门文章
  • SQL Server SQL获取第一条记录的方法
  • SQL Server出现System.OutOfMemoryException异常的解决方法
  • SQL Server的 update from 语句的简单示例
  • SQL Server 数据库备份方法菜鸟教程
  • SQL Server 多表关联时在where语句中慎用trim()方法
  • SQL Server数据类型及长度限制详细说明
  • mybaits非配置原因,导致SqlSession was not registered for synchronization异常解析
  • SQL Server 收缩后对数据库的使用有影响吗?
  • SQL Server 格式导致的Excel导入sql出现异常的解决方法
  • SQL Server 连接服务器出现错误 7391的解决方法
  • 最新文章
    • SQL Server存储过程基本语法的简单示例
    • sql查询时增加自动编号和分页的简单示例
    • sql轻松应付百万数据的高效数据分页存储过程的简单示例
    • sql获取一条数据中所有字段的名称和值的实现方法
    • sql分割函数的简单示例
    • SQL Server异常捕获的简单示例
    • SQL SERVER回滚恢复误操作数据的实现方法
    • SQL Server函数或存储过程中抛出异常的实现方法
    • SQL Server创建数据库的完整代码
    • SQL Server创建数据库的命令用法示例

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。