更换INTO和UPPLIC UPDATE不起作用

时间:2013-06-13 17:09:18

标签: mysql

我有表T1和每周如下:

CREATE TABLE T1 (
  C1 varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  C2 varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  timestamp timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
);

CREATE TABLE weekly (
  C1 varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  C2 varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  year year(4) DEFAULT NULL,
  week int(11) NOT NULL DEFAULT '0',
  count int(11)
);

基本上,我想按每年和每周的c1,c2对所有值组进行求和。需要将这些值存储到“每周”表中。此查询应每天运行,如果条目已存在则替换。

所以我尝试使用replace into。

replace into weekly select year(timestamp) as year,  week(timestamp) as week, C1, C2,  count(*) as count  from T1  where timestamp >= 20130606 and timestamp <= 20130613 group by C1,C2;

但是这个查询是在每周表中添加新条目而不是替换它。有什么问题?

1 个答案:

答案 0 :(得分:1)

您需要使用替换键才能按预期工作。

  

REPLACE的工作方式与INSERT完全相同,只是如果表中的旧行与PRIMARY KEY或UNIQUE索引的新行具有相同的值,则在插入新行之前删除旧行。请参见第13.2.5节“INSERT语法”。

https://dev.mysql.com/doc/refman/5.5/en/replace.html