现在需求在 mysql 的几张表中增加数据版本字段,来实现乐观锁控制并发更新的问题。
但是 mysql 不像 sqlserver 那边有数据版本类型的字段,只能通过触发器来实现。在创建触发器的过程中出现了报错,大体意思是要 super 权限,或者将 log_bin_trust_function_creators 设置成 1 ,但是这两个要求都没办法满足,项目中的账号没有修改以上配置的权限,申请目测也申请不到。
想过直接在代码中控制,但一个是麻烦,另外一个就是很难让其他开发者更新时都注意这个版本的更新。
请问一下有其他思路解决这个问题吗?
1
youngPacce 2023-11-07 19:35:43 +08:00 via Android
update set xxx=xxx where id=? and version = ?不知道符不符合你的需求
|
2
awesomePower OP @358343917 谢谢你的回答。就是为了达到这个更新的效果,所以需要维护 version 字段,我想知道的是是否有一个可行方案自动维护 version 的值
|
3
xcid 2023-11-07 23:00:31 +08:00
有些框架可以做到自动维护 version 。JPA 就可以。
|
4
XepMCWEKZ76L695l 2023-11-08 15:59:23 +08:00
mybatis plus 就可以,映射类加上 @version 注解就行
|
5
awesomePower OP @1Q1 这个我也注意到了。但是它的只适用几种更新的场景,没有强制所有更新语句都自动维护 version 值。比如说在 xml 的 sql 更新就不适用它那个功能
|
6
awesomePower OP @xcid 谢谢提供思路
|