我们有一个从csv文件插入数据的动态查询,我们想要的是更新所有的行,即使有重复的行。
我们知道这是可行的:
INSERT INTO TABLE (ID1,ID2,ID3,PAYDATE,PRICE,CURRENCY)
VALUES ('75','2','16','2018-11-5','300','CAD'),
('75','2','17','2018-11-10','400','USD')
ON DUPLICATE KEY UPDATE
ID1=VALUES(ID1),
ID2=VALUES(ID2),
ID3=VALUES(ID3),
PAYDATE=VALUES(PAYDATE),
PRICE=VALUES(PRICE),
CURRENCY=VALUES(CURRENCY)
但是,在创建动态查询时,这可能会变得复杂,因为我们之前不知道表的结构。因此,我们正在寻找一个类似的查询:
INSERT INTO TABLE (ID1,ID2,ID3,PAYDATE,PRICE,CURRENCY)
VALUES ('75','2','16','2018-11-5','300','CAD'),
('75','2','17','2018-11-10','400','USD')
ON DUPLICATE KEY UPDATE
(ID1,ID2,ID3,PAYDATE,PRICE,CURRENCY)
VALUES(ID1,ID2,ID3,PAYDATE,PRICE,CURRENCY)
最后一个显然不起作用,但对我们来说使用它更容易,因为我们已经在单个字符串中有了列,第一个查询需要将字符串分解成数组并执行几个嵌套循环。
//PHP
$cols = "ID1,ID2,ID3,PAYDATE,PRICE,CURRENCY";
$vals = "('75','2','16','2018-11-5','300','CAD'),
('75','2','17','2018-11-10','400','USD')";
$query = "INSERT INTO TABLE ($cols)
VALUES $vals
ON DUPLICATE KEY UPDATE
($cols) VALUES($cols)";
有类似的方法吗?
1条答案
按热度按时间e0bqpujr1#
您的php代码片段使您的意图更加清晰。
不,在sql查询中无法处理此问题。
但是,您可以简单地向php脚本添加“more magic”以生成所需的查询。
i、 e.您已经在创建正确的
INSERT
-语句(共2个数组)。所以,你需要做的就是创造一个合适的ON DUPLICATE KEY
-还有声明。:-)array_walk
,implode
以及explode
你的朋友在这里吗:将产生:
这应该是需要的。修改
wrapIt
排除在出现重复键时不希望更新的键/值对((如有)