码迷,mamicode.com
首页 > 数据库 > 详细

SQL 临时表或表变量替代游标

时间:2015-04-24 18:10:31      阅读:200      评论:0      收藏:0      [点我收藏+]

标签:

1.如果表没有自动增长的标识列(int) 使用临时表

SELECT IDENTITY(int) NewID ,.. INTO #tmp FROM YouTable

2.表有标识列 使用表变量

INSERT INTO @tmpTable
SELECT ..., NewID=(SELECT COUNT(*) FROM YouTable b WHERE b.aid<=a.aid) FROM YouTable a

当有了从 1到~d 的连续NewID时, 你就可以用循环来操作每一条记录了.
这个NewID你就可以当它是指针标识.

若不明白~~查看以下存储过程

/****** Object:  StoredProcedure [dbo].[aaa]    Script Date: 04/24/2015 15:11:25 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

Create PROCEDURE TableVariablesReplaceCursor
as
    declare @tmpTable table(NewID int,OldID int,OldName nvarchar(200),OtherName nvarchar(200))
    Begin   
    INSERT INTO @tmpTable SELECT NewID=(SELECT COUNT(*) FROM cj_MoneyCenter b WHERE b.KeyId<=a.KeyId),KeyId ,GeneralName,MoneyName FROM YourTable a
    DECLARE @i INT,@cnt INT
    SET @i=1
    SELECT @cnt=COUNT(*) FROM YourTable
    WHILE @i<=@cnt
         BEGIN
               SELECT * FROM @tmpTable WHERE NewID=@i
               SET @i=@i+1
         END
    End 

 

SQL 临时表或表变量替代游标

标签:

原文地址:http://www.cnblogs.com/ITgoodboy/p/4453640.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!