我怎么能写只是一个SQL查询来获取相同的结果通过执行这两个查询(步骤):嵌套SQL查询
第一步:
SELECT old_id, new_id FROM history WHERE flag = 1;
结果:
+--------+--------+
| old_id | new_id |
+--------+--------+
| 11 | 22 |
| 33 | 44 |
| 55 | 66 |
+--------+--------+
,然后使用以前的结果,执行这个查询:
UPDATE other_tabla SET somefk_id = CASE somefk_id
WHEN 11 THEN 22
WHEN 33 THEN 44
WHEN 55 THEN 66
END WHERE somefk_id IN (11,33,55)
+1`join`比`table1,table2`更具可读性:) – Andomar 2011-01-26 16:31:04