在重复键更新多个值 MYSQL
On duplicate key update multiple values MYSQL
我们有一个从 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)
但这在创建动态查询时会变得复杂,因为我们事先不知道 table 结构。所以我们正在寻找类似这样的查询:
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-Query 中没有办法处理这个问题。
但是,您可以简单地将 "more magic" 添加到 PHP-Script 以生成所需的查询。
即您已经从 2 个数组中创建了正确的 INSERT
-Statement。因此,您需要做的就是创建正确的 ON DUPLICATE KEY
-Statement。 :-)
array_walk
、implode
和 explode
是您的好友:
$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
以排除 key/value 对你不想在重复键的情况下更新。 (如果有的话)
我们有一个从 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)
但这在创建动态查询时会变得复杂,因为我们事先不知道 table 结构。所以我们正在寻找类似这样的查询:
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-Query 中没有办法处理这个问题。
但是,您可以简单地将 "more magic" 添加到 PHP-Script 以生成所需的查询。
即您已经从 2 个数组中创建了正确的 INSERT
-Statement。因此,您需要做的就是创建正确的 ON DUPLICATE KEY
-Statement。 :-)
array_walk
、implode
和 explode
是您的好友:
$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
以排除 key/value 对你不想在重复键的情况下更新。 (如果有的话)