sqlserver利用sp_cursoropen存储过程分页示例

declare @P1 int,@currIndex int;
declare @sql varchar(4000),@sql1 varchar(2000),@sql2 varchar(2000);
declare @data table(record_id int);

set @sql1 = 'select record_id from demo as t1 where 1=1 and in_qty >0';
set @sql2 = '';
set @currIndex=(@pageIndex-1)*@pagesize+1;

if @warehouseId > 0 set @sql2 = ' and t1.warehouse_id='+cast(@warehouseId as nvarchar);
if len(@startDate) > 0 set @sql2= @sql2 + ' and t1.bill_date >=''' + @startDate + '''';

set @sql = @sql1 + @sql2;
insert into @data exec  sp_cursoropen @P1 output,@sql,@scrollopt=1,@ccopt=1,@rowcount=@rowCount output;
insert into @data exec sp_cursorfetch @P1,16,@currIndex,@pagesize;
exec sp_cursorclose @P1;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值