今天看到一篇文章写的自己整理记录下,据说比用游标快。
declare @字段1 数据类型;
declare @字段2 数据类型;
declare @tmp_while_id int;
select tmp_while_id=identity(int,1,1),tmp_while_flag=0,
[字段1],[字段2],...
into #tmp_while from [表名] where [条件]....;
select @tmp_while_id=min(tmp_while_id) from #tmp_while where tmp_while_flag=0;
while @tmp_while_id is not null
begin
--获取当前处理行的信息
select @字段1=字段1,@字段2=字段2,... from #tmp_while where tmp_while_id=@tmp_while_id;
--<这里自己的处理过程>
--标识当前行已处理完毕
update #tmp_while set tmp_while_flag=1 where tmp_while_id=@tmp_while_id;
--选择下一行号
select @tmp_while_id=min(tmp_while_id) from #tmp_while where tmp_while_flag=0 and tmp_while_id>@tmp_while_id;
end
drop table #tmp_while;