1

我可以像这样组合两个查询吗

first: UPDATE table SET col1=1 WHERE id='x'; 

second: UPDATE table SET col1=0 WHERE id='y';

我可以将这些查询合二为一吗?

4

3 回答 3

4
UPDATE table
SET col1 = CASE id WHEN 'x' THEN 1 ELSE 0 END
WHERE id IN ('x','y')
于 2012-08-09T12:43:41.353 回答
0

使用这个 sql 查询:

UPDATE table
SET col1 = 
CASE id 
WHEN 'x' THEN 1 
WHEN 'y' THEN 0 
END
WHERE id IN ('x','y');

另请参阅MySQL 中的多个更新

于 2012-08-09T12:51:46.683 回答
0
UPDATE table
SET col1 = (id = 'x')
WHERE id IN ('x','y');
于 2012-08-09T12:55:21.583 回答