我很困惑我已经阅读了很多与此类似的不同问题,但仍然无法解决问题。
这是before表的一小段。 (POs_Parts)
+-------+------------+----------+---------+-------+----------+
| p_Key | f_key_part | f_key_po | partQty | r_qty | r_author |
+-------+------------+----------+---------+-------+----------+
| 0 | 18 | 6 | 2 | 0 | NULL |
| 1 | 19 | 6 | 3 | 0 | NULL |
| 2 | 20 | 6 | 1 | 0 | NULL |
| 3 | 18 | 8 | 1 | 0 | NULL |
+-------+------------+----------+---------+-------+----------+
这是我希望更新语句后的样子。 (最后两列已更新)
+-------+------------+----------+---------+-------+----------+
| p_Key | f_key_part | f_key_po | partQty | r_qty | r_author |
+-------+------------+----------+---------+-------+----------+
| 0 | 18 | 6 | 2 | 2 | John |
| 1 | 19 | 6 | 3 | 2 | John |
| 2 | 20 | 6 | 1 | 0 | John |
| 3 | 18 | 8 | 1 | 1 | John |
+-------+------------+----------+---------+-------+----------+
我认为该语句可以完成我想要的-一行-但是我有很多行需要一次更改,因此我想避免一次执行很多语句。
UPDATE POs_Parts SET r_qty = 2, r_author='John' where f_key_part = 18 and f_key_po = 6;
这是我试图用作参考的问题。 Multiple Updates in MySQL
如何在不必运行
Update
语句的情况下重写它?我将使用PHP
创建查询。任何建议,将不胜感激。 最佳答案
如果您遵循链接的参考,则SQL将类似于
INSERT INTO
POs_Parts (p_Key, f_key_part, f_key_po, partQty, r_qty, r_author)
VALUES
(0, 18, 6, 2, 2, 'John'),
(1, 19, 6, 3, 2, 'John'),
(2, 20, 6, 1, 0, 'John'),
(3, 18, 8, 1, 1, 'John')
ON DUPLICATE KEY UPDATE
f_key_part = VALUES(f_key_part),
f_key_po = VALUES(f_key_po),
partQty = VALUES(partQty),
r_qty = VALUES(r_qty),
r_author = VALUES(r_author)
(您可能可以省略未更改的列-我以前没有测试过或从未使用过这种语法。~~编辑:您不能忽略这些列~~编辑2:您可以省略这些列。请参见下面的更新语法)
我认为您会发现“一堆SQL语句”是更简单的方法。
这是我的测试:
MariaDB [test]> select * from POs_Parts;
+-------+------------+----------+---------+-------+----------+
| p_Key | f_key_part | f_key_po | partQty | r_qty | r_author |
+-------+------------+----------+---------+-------+----------+
| 0 | 18 | 6 | 2 | 0 | NULL |
| 1 | 19 | 6 | 3 | 0 | NULL |
| 2 | 20 | 6 | 1 | 0 | NULL |
| 3 | 18 | 8 | 1 | 0 | NULL |
+-------+------------+----------+---------+-------+----------+
4 rows in set (0.00 sec)
MariaDB [test]> INSERT INTO POs_Parts (p_Key, f_key_part, f_key_po, partQty, r_qty, r_author) VALUES (0, 18, 6, 2, 2, 'John'), (1, 19, 6, 3, 2, 'John'), (2, 20, 6, 1, 0, 'John'), (3, 18, 8, 1, 1, 'John') ON DUPLICATE KEY UPDATE f_key_part = VALUES(f_key_part), f_key_po = VALUES(f_key_po), partQty = VALUES(partQty), r_qty = VALUES(r_qty), r_author = VALUES(r_author);
Query OK, 8 rows affected (0.00 sec)
Records: 4 Duplicates: 4 Warnings: 0
MariaDB [test]> select * from POs_Parts;
+-------+------------+----------+---------+-------+----------+
| p_Key | f_key_part | f_key_po | partQty | r_qty | r_author |
+-------+------------+----------+---------+-------+----------+
| 0 | 18 | 6 | 2 | 2 | John |
| 1 | 19 | 6 | 3 | 2 | John |
| 2 | 20 | 6 | 1 | 0 | John |
| 3 | 18 | 8 | 1 | 1 | John |
+-------+------------+----------+---------+-------+----------+
4 rows in set (0.00 sec)
较短的语法:
INSERT INTO
POs_Parts (p_Key, r_qty, r_author)
VALUES
(0, 2, 'John'),
(1, 2, 'John'),
(2, 0, 'John'),
(3, 1, 'John')
ON DUPLICATE KEY UPDATE
r_qty = VALUES(r_qty),
r_author = VALUES(r_author)