gpt4 book ai didi

Mysql用前一条记录的值更新一条记录

转载 作者:行者123 更新时间:2023-11-29 01:14:24 26 4
gpt4 key购买 nike

我有下表,我想做的是更新,例如,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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com