我有以下数据:只用一个查询更新多行?
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
马丁·史密斯的解决方案肯定是少数行的最佳解决方案实现这一目标。如果要更新更多行数,最好使用不同的值发布几个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
。
您可以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;
检查此博客:http://www.kavoir.com/2009/05/mysql-update-multiple-rows-with-one-single-query.html - 第一个结果,当我搜索更新多行与单个查询 – karthikr