关于 mysql 乐观锁问题求助

2023-11-07 17:18:10 +08:00
 awesomePower

现在需求在 mysql 的几张表中增加数据版本字段,来实现乐观锁控制并发更新的问题。

但是 mysql 不像 sqlserver 那边有数据版本类型的字段,只能通过触发器来实现。在创建触发器的过程中出现了报错,大体意思是要 super 权限,或者将 log_bin_trust_function_creators 设置成 1 ,但是这两个要求都没办法满足,项目中的账号没有修改以上配置的权限,申请目测也申请不到。

想过直接在代码中控制,但一个是麻烦,另外一个就是很难让其他开发者更新时都注意这个版本的更新。

请问一下有其他思路解决这个问题吗?

799 次点击
所在节点    MySQL
6 条回复
youngPacce
2023-11-07 19:35:43 +08:00
update set xxx=xxx where id=? and version = ?不知道符不符合你的需求
awesomePower
2023-11-07 19:48:06 +08:00
@358343917 谢谢你的回答。就是为了达到这个更新的效果,所以需要维护 version 字段,我想知道的是是否有一个可行方案自动维护 version 的值
xcid
2023-11-07 23:00:31 +08:00
有些框架可以做到自动维护 version 。JPA 就可以。
XepMCWEKZ76L695l
2023-11-08 15:59:23 +08:00
mybatis plus 就可以,映射类加上 @version 注解就行
awesomePower
2023-11-08 16:54:51 +08:00
@1Q1 这个我也注意到了。但是它的只适用几种更新的场景,没有强制所有更新语句都自动维护 version 值。比如说在 xml 的 sql 更新就不适用它那个功能
awesomePower
2023-11-08 16:55:44 +08:00
@xcid 谢谢提供思路

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/989595

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX