请问下大佬,方法没有全局事务需求,也没查询需求,不加for update。但是有修改需求,怎么避免

22c70cb91947f69507a54e2890dfd4d7.jpg 请问下大佬,方法没有全局事务需求,也没查询需求,不加for update。但是有修改需求,怎么避免脏写啊?

展开
收起
真的很搞笑 2023-04-03 12:31:34 266 分享 版权
2 条回答
写回答
取消 提交回答
  • 修改的方法加上全局事务,此回答整理自钉群“3群-Seata 开源讨论群”

    2023-04-03 18:30:41
    赞同 展开评论
  • 可以通过加锁的方式来避免脏写。比如可以使用行级锁或表级锁来进行加锁,确保同一时刻只有一个事务在修改数据,避免并发修改导致的脏写。

    如果你的数据库是 MySQL,那么可以使用以下语句来进行行级锁的加锁操作:

    SELECT ... FOR UPDATE; 如果想要对整张表进行加锁,可以使用以下语句:

    LOCK TABLES table_name WRITE; 在操作完成后,需要释放锁:

    UNLOCK TABLES;

    2023-04-03 13:01:35
    赞同 展开评论
问答地址:

为企业提供高效、稳定、易扩展的中间件产品。

收录在圈子:
+ 订阅
阿里云中间件主要有包含这么几个: 分布式关系型数据库DRDS_水平拆分 做数据库扩展性的 、消息队列MQ 是做消息的中间件、企业级分布式应用服务EDAS 做分布式服务的、还有一些其他的中间件,比如配置服务、缓存等等。
还有其他疑问?
咨询AI助理