职业IT人-IT人生活圈

 找回密码
 成为会员
搜索
查看: 1618|回复: 0

sql2005存储过程调用游标及分页

[复制链接]
蓝色梦幻 发表于 2008-3-4 16:16 | 显示全部楼层 |阅读模式
--删除语句
--drop proc proc_proc
--创建
create proc proc_proc
--传入参数
@Flag int,
@UserID nvarchar(50),
@BeginTime datetime,
@EndTime datetime,
@PageIndex int,
@PageSize int
as
--创建临时表
create table #tmp(
id uniqueidentifier,
UserAccount nvarchar(50),
Content nvarchar(255),
ScheduledTime datetime,
CreatedTime datetime,
Status int,
SubmitCount int,
Flag int
)
--传出参数
declare @TotalCount int
--声明游标
declare my_cursor cursor scroll
for
select distinct BatchID from SmsSubmit
where UserAccount= @UserID
and CreatedTime<(select DATEADD ( dd , 1, @EndTime )) and CreatedTime>(select DATEADD ( dd , -1, @BeginTime ))
and Flag=@Flag
open my_cursor
declare @BatchID nvarchar(50)
fetch next from my_cursor into @BatchID
while(@@fetch_status=0)
begin
  --插入临时表
  insert into #tmp
  select TOP 1 id,UserAccount,Content,ScheduledTime,CreatedTime,Status,SubmitCount,Flag from SmsSubmit where BatchID=@BatchID ORDER by CreatedTime desc
fetch next from my_cursor into @BatchID
end
close my_cursor
deallocate my_cursor--删除游标
select @TotalCount=count(*) from #tmp
--分页
select * from(select *,row_number() over(order by CreatedTime) as rownum from #tmp) as a
where rownum BETWEEN (@PageIndex-1)*(@PageSize+1 )
AND @PageIndex*@PageSize order by CreatedTime
--删除临时表
drop table #tmp
return @TotalCount
--创建完毕
--调运存储过程
exec proc_proc1,&#39;zjh123&#39;,&#39;2008-1-29 0:00:00&#39;,&#39;2008-3-3 0:00:00&#39;,1,10
存储过程创建的背景:源于一个表中相同的BatchID却对应有多条不同的表记录,但只想取出 where条件后的不同用户的一条BatchID
您需要登录后才可以回帖 登录 | 成为会员

本版积分规则

QQ|手机版|小黑屋|网站帮助|职业IT人-IT人生活圈 ( 粤ICP备12053935号-1 )|网站地图
本站文章版权归原发布者及原出处所有。内容为作者个人观点,并不代表本站赞同其观点和对其真实性负责,本站只提供参考并不构成任何投资及应用建议。本站是信息平台,网站上部分文章为转载,并不用于任何商业目的,我们已经尽可能的对作者和来源进行了通告,但是能力有限或疏忽造成漏登,请及时联系我们,我们将根据著作权人的要求立即更正或者删除有关内容。

GMT+8, 2024-5-9 21:19 , Processed in 0.123843 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表