关于SQL储存过程中输出多行数据

declare @num1 int            --为符合条件的总行数

select @num1=COUNT(1) from cardInfo where openDate between @date1 and @date2 

    --@date1 和 @date2 为开始时间到结束时间,可以理解一个条件

while(@num1<>0)     --和下面的set@num1-=1形成循环的次数
begin
print @num1                       --循环输出@num1的值,依次减一
set @num1-=1
select top 1 @uid= cardID from cardInfo where cardID             --@uid为表的卡号,使用分页(每页1页的方式)
not in(select top (@num1) cardID from cardInfo) and   --除去前 (@num1-1)行的数据

 openDate in(select openDate from cardInfo where openDate between @date1 and @date2 )           --where条件
print @uid                                --循环输出想要的数据信息
end

posted @ 2016-08-18 20:14  wyd12138  阅读(827)  评论(0编辑  收藏  举报