快速更新SQL Server表中的所有行
有没有更有效的方法来编写这段代码? 或者用更少的代码?
SELECT *
INTO #Temp
FROM testtemplate
Declare @id INT
Declare @name VARCHAR(127)
WHILE (SELECT Count(*) FROM #Temp) > 0
BEGIN
SELECT TOP 1 @id = testtemplateid FROM #Temp
SELECT TOP 1 @name = name FROM #Temp
UPDATE testtemplate
SET testtemplate.vendortestcode = (SELECT test_code FROM test_code_lookup WHERE test_name = @name)
WHERE testtemplateid = @id
--finish processing
DELETE #Temp Where testtemplateid = @id
END
DROP TABLE #Temp
您可以在单个UPDATE中执行此操作,而无需循环。
UPDATE tt
SET vendortestcode = tcl.test_code
FROM testtemplate tt
INNER JOIN test_code_lookup tcl
ON tt.name = tcl.test_name
你可以尝试像这样的单个更新:
UPDATE A
SET A.vendortestcode = B.test_code
FROM testtemplate A
INNER JOIN test_code_lookup B
ON A.name = B.test_name
另外,你现在这样做的方式是错误的 ,因为你在两个单独的querys中取得了TOP 1 ID和TOP 1名称,没有ORDER BY
,所以它不确定你是否为你的ID使用了正确的名字。
你可以写一个函数来更新vendortestcode。 然后你的代码减少到一个SQL语句:
update testtemplate set vendortestcode = dbo.get_test_code_from_name(name)
链接地址: http://www.djcxy.com/p/94669.html