首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >关于重复键更新多个值MYSQL

关于重复键更新多个值MYSQL
EN

Stack Overflow用户
提问于 2018-10-19 20:57:59
回答 1查看 1.5K关注 0票数 1

我们有一个动态查询,它从CSV文件中插入数据,我们想要的是更新所有的行,即使有重复的。

我们知道这是可行的:

代码语言:javascript
复制
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)

但是,在创建动态查询时,这会变得非常复杂,因为在动态查询中,我们不知道前面的表结构。因此,我们正在寻找一个类似于以下内容的查询:

代码语言:javascript
复制
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)

最后一个显然不起作用,但是我们使用它更容易,因为我们已经有一个字符串中的列,第一个查询需要将字符串炸成一个数组并执行几个嵌套循环。

代码语言:javascript
复制
//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)";

有类似的方法吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-19 23:10:19

PHP代码片段使您的意图更加清晰。

不,在SQL-查询中无法处理这个问题。

但是,您可以简单地向PHP脚本添加“更多魔法”,以生成所需的查询。

也就是说,您已经在从两个数组中创建适当的INSERT-Statement。因此,您所需要做的就是创建适当的ON DUPLICATE KEY-Statement。:-)

array_walkimplodeexplode是你在这里的朋友:

代码语言:javascript
复制
$cols = "ID1,ID2,ID3,PAYDATE,PRICE,CURRENCY";
$vals = "('75','2','16','2018-11-5','300','CAD'),
    ('75','2','17','2018-11-10','400','USD')";

//Create a pseudoArray, with VALUES() Keyword
$pseudoArray = explode(",", $cols);
array_walk($pseudoArray, "wrapIt");

function wrapIt(&$item, $value){
   $item = $item . "=VALUES(" . $item . ")";
}

$query = "INSERT INTO TABLE ($cols) 
    VALUES $vals
    ON DUPLICATE KEY UPDATE
    " . implode(",", $pseudoArray);


echo $query;

将产生:

代码语言:javascript
复制
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)

这应该是我们所需要的。修改wrapIt以排除在重复键情况下不想更新的键/值对。(如有的话)

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52899826

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档