sqlserver存储过程分页查询

1.单表查询分页存储过程

CREATE PROCEDURE [dbo].[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,                        --分页大小
	@GetCount int =0,						   --获取的记录总数,0则获取记录总数,不为0则不获取
	@Count int = 0 output					   --总数
)
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)
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值