mySQL更新接下来的12个NULL值,日期增加1

时间:2016-04-28 14:48:13

标签: mysql sql date auto-increment

基本上,我有这两个查询:

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;

感谢您的帮助。

1 个答案:

答案 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