mysql - MYSQL 重复键更新多个值

标签 mysql on-duplicate-key

我们有一个从 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)";

有类似的方法吗?

最佳答案

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

不,没有办法在 SQL 查询中处理这个问题。

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

即您已经从 2 个数组中创建了正确的 INSERT 语句。因此,您所需要做的就是创建正确的 ON DUPLICATE KEY 语句。 :-)

array_walkimplodeexplode 是您的 friend :

$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;

将产生:

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 以排除您不想在出现重复键时更新的键/值对。 (如有)

关于mysql - MYSQL 重复键更新多个值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52899826/

相关文章:

mysql - 在 MySQL Point 字段中反转 X 和 Y 坐标

mysql - 优化分页的 DISTINCT/LIMIT MySQL 查询

java - Tomcat 第一次响应慢

php - 在重复键更新时插入选择

mysql - 关于重复 key 更新 - 优先级

mysql - 在 MySQL 上更新无符号 INT 失败并出现低值

MySQL Workbench - 无法看到文本输出结果

根据提供的成分搜索 PHP MySQL 食谱

mysql - 如何对多个记录使用 ON DUPLICATE KEY 为每个记录(如果不存在)创建一个新记录

mysql - 向表中插入非重复数据