使用SQL添加/更新批量数据

时间:2016-05-03 16:23:22

标签: sql sql-server database while-loop

我们正在使用SQL Server Management studio将批量数据插入到我们的数据库表中。目前,我们处于将发送到数据库的数据添加到表中的特定行的位置(这由存储过程控制)。我们发现的是在操作完成之前发生超时;在这一点上,我们认为由于while循环操作很慢,但我们不确定如何编写更快的等价物。

-- Insert statements for procedure here
WHILE @i < @nonexistingTblCount
BEGIN
    Insert into AlertRanking(MetricInstanceID,GreenThreshold,RedThreshold,AlertTypeID,MaxThreshold,MinThreshold) 
    VALUES ((select id from @nonexistingTbl order by id OFFSET @i ROWS FETCH NEXT 1 ROWS ONLY), @greenThreshold, @redThreshold, @alertTypeID, @maxThreshold, @minThreshold) 

    set @id = (SELECT ID FROM AlertRanking 
    WHERE MetricInstanceID = (select id from @nonexistingTbl order by id OFFSET @i ROWS FETCH NEXT 1 ROWS ONLY)
    AND GreenThreshold = @greenThreshold
    AND RedThreshold = @redThreshold
    AND AlertTypeID = @alertTypeID);

    set @i = @i + 1;
END

其中@nonexistingTblCount是表格@nonexistingTbl内的总行数。 @nonexistingTbl表是先前声明的,包含我们要添加到表中的所有值。

1 个答案:

答案 0 :(得分:1)

您应该能够使用单个语句插入所有记录,而不是使用循环。

INSERT INTO AlertRanking(MetricInstanceID,GreenThreshold,RedThreshold,AlertTypeID,MaxThreshold,MinThreshold) 
SELECT id, @greenThreshold, @redThreshold, @alertTypeID, @maxThreshold, @minThreshold FROM @nonexistingTbl ORDER BY id