我有以下数据:
id = 1
name = 'john'
id = 2
name = 'jimmy'
等等
有没有办法只使用一个查询来更新我的表?
Table
id | name
1 | johnny
2 | james
我有以下数据:
id = 1
name = 'john'
id = 2
name = 'jimmy'
等等
有没有办法只使用一个查询来更新我的表?
Table
id | name
1 | johnny
2 | james
你可以用CASE
UPDATE YourTable
SET name = CASE
WHEN id = 1 THEN 'johnny'
ELSE 'james'
END
WHERE id IN ( 1, 2 )
或另一种可能性(SQL Fiddle)
UPDATE YourTable a
JOIN
( SELECT 1 AS id, 'johnny' AS name
UNION ALL
SELECT 2 AS id, 'james' AS name
) b ON
b.id = a.id
SET a.name = b.name;
Martin Smith 的解决方案无疑是少数行的最佳解决方案。如果要更新更多的行,您最好发出几个UPDATES
具有不同值的行,可能在准备好的语句的帮助下。
只是为了好玩,我设计了另一个解决方案:
MEMORY
表UPDATE your_table JOIN temp_table ON (<insert JOIN condition here>) SET your_table.field1 = temp_table.field1, your_table.field2 = temp_table.field2
。嗯,这闻起来。严重地。使用准备好的UPDATE
.