首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >具有增量值的MySQL更新行

具有增量值的MySQL更新行
EN

Stack Overflow用户
提问于 2017-01-30 19:22:36
回答 3查看 694关注 0票数 1

我有一张有两列的桌子。在这个例子中,我移除了一些额外的列。实际上还有5列。

  • 目录
  • 味精

它的人口如下:

代码语言:javascript
复制
msgnum    dir
0         /var/spool/asterisk/voicemail/test/1/INBOX
1         /var/spool/asterisk/voicemail/test/1/INBOX
2         /var/spool/asterisk/voicemail/test/1/INBOX
3         /var/spool/asterisk/voicemail/test/1/INBOX
4         /var/spool/asterisk/voicemail/test/1/INBOX
5         /var/spool/asterisk/voicemail/test/1/INBOX
0         /var/spool/asterisk/voicemail/test/1/Old
1         /var/spool/asterisk/voicemail/test/1/Old
0         /var/spool/asterisk/voicemail/test/2/INBOX
1         /var/spool/asterisk/voicemail/test/2/INBOX

注意,msgnum并不是唯一的。它对每个“dir”值都是唯一的。

当删除记录时,我希望重新计算并更新每行的msgnum字段,保持msgnum的顺序。因此,如果删除了包含msgnum=3的记录,msgnum 4和5将被更新为“向上移动”。

在纯MySQL中可以做到这一点吗?

谢谢

EN

回答 3

Stack Overflow用户

发布于 2017-01-30 19:28:17

您可以使用触发器来实现这一点。在您的表中,转到更多的->触发器,并选择何时应该触发它,在本例中:-删除后,然后编写您的SQL。例如。

代码语言:javascript
复制
UPDATE table SET msgnum = msgnum-1 WHERE msgnum > OLD.msgnum

其中OLD.msgnum将是已删除的msgnum。

抱歉,我的英语不好

票数 0
EN

Stack Overflow用户

发布于 2017-01-30 19:34:46

由于您已经通过PHP执行sql,因此我将基于此回答。

您需要按照数据库事务内部的顺序执行以下2平方米:

代码语言:javascript
复制
delete from mytable where msgnum = 3;
update mytable set msgnum = msgnum - 1 where msgnum > 3;

您需要在事务中执行此操作,以便如果更新失败,还可以安全地回滚delete。

PHP文档中的事务示例

票数 0
EN

Stack Overflow用户

发布于 2017-01-30 20:33:10

我设法找到了我的解决方案,因此可以认为这是重复的。

mysql根据顺序使用int更新列

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41943845

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档