SQL Server 分页查询通用存储过程(只做分页查询用)
作者:whsnow 时间:2024-01-12 20:10:11
自开始做项目以来,一直在用。这段存储过程的的原创者(SORRY,忘记名字了),写得这段SQL代码很不错,我在这个基础上,按照我的习惯以及思维方式,调整了代码,只做分页查询用。
/*----------------------------------------------
*procedure name : P_PageResult
* author :Fay
* create date : 2014-07-18
*/
CREATE PROCEDURE prcPageResult
-- 获得某一页的数据 --
@currPage int = 1, --当前页页码 (即Top currPage)
@showColumn varchar(2000) = '*', --需要得到的字段 (即 column1,column2,......)
@tabName varchar(2000), --需要查看的表名 (即 from table_name)
@strCondition varchar(2000) = '', --查询条件 (即 where condition......) 不用加where关键字
@ascColumn varchar(100) = '', --排序的字段名 (即 order by column asc/desc)
@bitOrderType bit = 0, --排序的类型 (0为升序,1为降序)
@pkColumn varchar(50) = '', --主键名称
@pageSize int = 20 --分页大小
AS
BEGIN -- 存储过程开始
-- 该存储过程需要用到的几个变量 --
DECLARE @strTemp varchar(1000)
DECLARE @strSql varchar(4000) --该存储过程最后执行的语句
DECLARE @strOrderType varchar(1000) --排序类型语句 (order by column asc或者order by column desc)
BEGIN
IF @bitOrderType = 1 -- bitOrderType=1即执行降序
BEGIN
SET @strOrderType = ' ORDER BY '+@ascColumn+' DESC'
SET @strTemp = '<(SELECT min'
END
ELSE
BEGIN
SET @strOrderType = ' ORDER BY '+@ascColumn+' ASC'
SET @strTemp = '>(SELECT max'
END
IF @currPage = 1 -- 如果是第一页
BEGIN
IF @strCondition != ''
SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@showColumn+' FROM '+@tabName+
' WHERE '+@strCondition+@strOrderType
ELSE
SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@showColumn+' FROM '+@tabName+@strOrderType
END
ELSE -- 其他页
BEGIN
IF @strCondition !=''
SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@showColumn+' FROM '+@tabName+
' WHERE '+@strCondition+' AND '+@pkColumn+@strTemp+'('+@pkColumn+')'+' FROM (SELECT TOP '+STR((@currPage-1)*@pageSize)+
' '+@pkColumn+' FROM '+@tabName+@strOrderType+') AS TabTemp)'+@strOrderType
ELSE
SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@showColumn+' FROM '+@tabName+
' WHERE '+@pkColumn+@strTemp+'('+@pkColumn+')'+' FROM (SELECT TOP '+STR((@currPage-1)*@pageSize)+' '+@pkColumn+
' FROM '+@tabName+@strOrderType+') AS TabTemp)'+@strOrderType
END
END
EXEC (@strSql)
END -- 存储过程结束
------------------------------------------------
GO
调用方法:
prcPageResult 1,'*','TableName','','CreateDate',1,'PkID',25
上面表示,查询表TableName的所有字段,前25条记录,因为是第一页,排序字段为CreateDate,降序排列,主键是PkID。这个存储过程的功能比较强大,用在项目中非常的适用。不信您可以试试看,尤其是在百万级数据上,他的优势就显露无疑了,当然,这段代码是可以转换成MySql中的存储过程的,不过,在这里就不给大家了,你们可以自己试着转换看看。
下面的存储过程查询表的记录数:
/*----------------------------------------------
*procedure name : prcRowsCount
* author :Fay
* create date : 2014-07-18
*/
CREATE PROC prcRowsCount
@tabName varchar(200), --需要查询的表名
@colName varchar(200)='*', --需要查询的列名
@condition varchar(200)='' --查询条件
AS
BEGIN
DECLARE @strSql varchar(255)
IF @condition = ''
SET @strSql='select count('+@colName+') from '+@tabName
ELSE
SET @strSql='select count('+@colName+') from '+@tabName+' where '+@condition
EXEC (@strSql)
END
------------------------------------------------
GO
还有删除记录的通用存储过程和查询单条记录的通用存储过程在这里就不奉送了,感谢提供原通用分页查询存储过程的哥们,谢谢。
标签:分页查询,存储过程
0
投稿
猜你喜欢
uwsgi+nginx部署Django项目操作示例
2021-05-04 02:23:50
SpringBoot使用flyway初始化数据库
2024-01-28 13:43:38
Python采集C站热榜数据实战示例
2022-05-03 13:13:13
Ubuntu10下如何搭建MySQL Proxy读写分离探讨
2024-01-20 08:04:43
JavaScript中的Math.atan2()方法使用详解
2024-05-03 15:57:13
pyppeteer执行js绕过webdriver监测方法上
2021-12-13 12:04:40
解决Python图形界面中设置尺寸的问题
2022-11-12 12:05:02
关于msyql事务隔离你要知道
2024-01-27 11:07:31
PHP实现页面静态化的超简单方法
2023-11-18 17:13:24
用PHP编写每周签到功能以提高用户参与度
2023-05-27 17:24:54
Python调用shell命令常用方法(4种)
2021-05-06 08:22:06
javascript 正则表达式相关应介绍
2024-04-10 14:02:39
mysql格式化小数保留小数点后两位(小数点格式化)
2024-01-21 10:33:58
Python之lambda匿名函数及map和filter的用法
2021-01-14 02:11:18
四行Python3代码实现图片添加美颜效果
2021-01-25 10:29:30
PyTorch中的Variable变量详解
2023-02-19 18:48:47
MySQL用户权限设置保护数据库安全
2024-01-16 09:03:07
vue使用iframe嵌入网页的示例代码
2024-05-05 09:12:04
asp动态页面防采集的新方法
2011-02-26 10:44:00
centos 安装mysql中遇到问题的解决办法
2010-12-14 15:11:00