mySQL 更新接下来的 12 个 NULL 值,日期递增 1
mySQL update next 12 NULL values with date increment by 1
基本上,我有这两个问题:
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 等等
Table定义
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;
感谢您的帮助。
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
基本上,我有这两个问题:
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 等等
Table定义
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;
感谢您的帮助。
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