我有下表,我想做的是更新,例如,RefIDs 3-14 具有与先前值相同的状态值“已添加”。我想这样做直到它达到下一个完成值。因此,当它遇到“已添加”时,它会用“已添加”更新下面所有具有空值的行,直到它到达下一个具有已填充状态的 RefID,然后更新下一批值。这可以做到吗?任何帮助将不胜感激。我希望它是动态的,因为我不想手动更新 Status = "Added",其中 RefID 为 3。
RefID Status<br/>
1 Null
<br/>
<ul>2 Added</ul><br/>
<ul>3 Null</ul><br/>
<ul>4 Null</ul><br/>
<ul>5 Changed</ul><br/>
<ul>6 Null</ul><br/>
<ul>7 Null</ul>
我想实现的是这样的:
RefID Status<br/>
1 Null
<br/>
<ul>2 Added</ul><br/>
<ul>3 Added</ul><br/>
<ul>4 Added</ul><br/>
<ul>5 Changed</ul><br/>
<ul>6 Changed</ul><br/>
<ul>7 Changed</ul>
最佳答案
试试这个查询 -
UPDATE refs_table t1
JOIN (
SELECT RefID, @s:=IF(Status IS NULL, @s, Status) Status
FROM (SELECT * FROM refs_table ORDER BY RefID) r,
(SELECT @s:=NULL) t
) t2
ON t1.RefID = t2.RefID
SET t1.Status = t2.Status
关于Mysql用前一条记录的值更新一条记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9497754/