基本上,我有这两个查询:
SELECT * FROM table
WHERE langue = 'fr' AND hDate IS NULL
LIMIT 12;
UPDATE table
SET hDate = CURDATE() + INTERVAL 1 DAY
WHERE hDate IS NULL
LIMIT 12;
这些工作适用于前12个NULL记录。如果我需要更新下12个NULL记录,我必须手动将UPDATE查询更改为INTERVAL 2 DAY
问题是我有4000条记录。
我试过了
UPDATE table t1 JOIN
(
SELECT id, @n := @n + 1 rnum
FROM table CROSS JOIN (SELECT @n := 0) i
WHERE langue = 'fr'
ORDER BY id
) t2 ON t1.id = t2.id CROSS JOIN
(
SELECT MAX(hDate) sdate FROM table
) q
SET t1.hDate = q.sdate + INTERVAL t2.rnum DAY
来自这个答案:MySQL query to update records with incremented date
但是这会使每条记录增加1天。我必须增加12个相同日期的记录,接下来的12个记录,日期+ 1,接下来的12个记录,日期+2等。
表格定义
CREATE TABLE `table` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`texte` mediumtext,
`langue` varchar(9) DEFAULT NULL,
`hDate` date DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6726 DEFAULT CHARSET=utf8;
感谢您的帮助。
答案 0 :(得分:1)
http://sqlfiddle.com/#!9/7a554/1
SET @i:=0;
SET @j:=0;
UPDATE t1
RIGHT JOIN (
SELECT
id
,IF(@j = 0 ,@j:=1, @j:=@j+1)
,IF((@j-1) % 12 = 0, @i:= @i+1, @i) as i
FROM t1
WHERE hDate IS NULL
) idx
on idx.id = t1.id
SET t1.hDate = CURDATE() + INTERVAL (idx.i) DAY