mysql有int字段只增不减功能

发布于 2022-09-03 09:25:46 字数 202 浏览 14 评论 0

现在有一个字段,类型为int,能否仅通过mysql自身的sql语句或配置,来实现该字段只增不减的功能?

比如说现在有一条记录,这个字段的值是1400,现在要对该字段进行UPDATE操作,当UPDATE SET为1300时,就失败,当UPDATE SET为1500时,就成功。

我不想通过后端代码来实现的原因,是因为觉得为了更新记录,单独再查一遍,有点浪费了。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

杯别 2022-09-10 09:25:46

update test set value=1500 where id=1 and value<1500

然后获取影响条数就可以了。

最后,你要留意这个值,这样的更新在并发的情况下,无法做到数据的一致性。

春花秋月 2022-09-10 09:25:46

可以尝试设置触发器

薄荷梦 2022-09-10 09:25:46

触发器可以做到的

娇女薄笑 2022-09-10 09:25:46

我今天也遇到这个问题了,目前找到两种方法,一种是mybaits里xml

update 表 AS a
inner join(select a.值 from 表 AS a WHERE 匹配条件) b
SET
a.值 =GREATEST(b.值, #{变量})
WHERE
匹配条件

一种设置触发器,设置触发器是强约束,如果再想改小只能先删后加

CREATE TRIGGER `触发器名字` BEFORE UPDATE ON `表` FOR EACH ROW SET NEW.值 = GREATEST(NEW.值, OLD.值);

不知道还有没有更好的方法

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文