我有表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;
但是这个查询是在每周表中添加新条目而不是替换它。有什么问题?
答案 0 :(得分:1)
您需要使用替换键才能按预期工作。
REPLACE的工作方式与INSERT完全相同,只是如果表中的旧行与PRIMARY KEY或UNIQUE索引的新行具有相同的值,则在插入新行之前删除旧行。请参见第13.2.5节“INSERT语法”。