我在使用 INSERT SELECT ON DUPLICATE KEY UPDATE 查询时遇到了一些问题。我想为选择返回的每一行执行诸如增加表中的字段之类的操作,其中一些需要更新同一行。
设置:
表源
CREATE TABLE `source` (
`key` int(11) NOT NULL AUTO_INCREMENT,
`data` int(11) DEFAULT NULL,
`state` int(11) DEFAULT NULL,
`group` int(11) DEFAULT NULL,
PRIMARY KEY (`key`)
);
表目标
CREATE TABLE `dest` (
`dkey` int(11) NOT NULL,
`ddata` int(11) DEFAULT NULL,
`dstate` int(11) NOT NULL,
PRIMARY KEY (`dkey`,`dstate`)
) ;
源测试值
INSERT INTO `source` (`key`,`data`,`state`,`group`) VALUES (1,1,1,1);
INSERT INTO `source` (`key`,`data`,`state`,`group`) VALUES (2,2,2,1);
INSERT INTO `source` (`key`,`data`,`state`,`group`) VALUES (8,4,2,1);
询问:
INSERT INTO `test`.`dest` (`dkey`,`ddata`,`dstate`)
SELECT `group`,`data`,`state` FROM `test`.`source`
WHERE `group` = 1
ON DUPLICATE KEY UPDATE
`ddata`= `ddata`+VALUES(`ddata`);
我需要它做的是当 dest 中不存在该行时创建一个数据 = 1 的新行。当该行已经存在时,我需要它来增加数据。
执行上述查询后,结果如下:
dkey ddata dstate
1 1 1
1 4 2
我希望他们在哪里
1 1 1
1 6 2
它不是添加到先前的值,而是替换它。
有什么建议么?