3

我在使用 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   

它不是添加到先前的值,而是替换它。

有什么建议么?

4

1 回答 1

1

复制时,我得到以下结果:

1, 1, 1
1, 6, 2

这似乎是正确的,因为您的源数据中有data = 1forstate = 1data = 2, 4for state = 2

你为什么期待2第一张唱片?

于 2011-04-20T10:22:19.140 回答