Mysql_锁定读取

在MySQL中,为了在事务中确保数据安全,可以使用锁定读取来防止其他事务修改查询到的数据。锁定读取分为共享模式锁定和排他模式锁定,用于保护单个表或跨表的数据操作。在事务中,锁定读取的锁定会在提交或回滚时释放,但必须在禁用自动提交的情况下才能使用。这种技术在处理引用完整性、递增计数器等场景时非常关键,能有效避免并发操作导致的问题。
摘要由CSDN通过智能技术生成
锁定读取

如果查询数据,然后在同一事务中插入或更新相关数据,则常规SELECT 语句不能提供足够的保护。其他事务可以更新或删除刚查询的相同行。 InnoDB支持两种类型的 锁定读取,这些读取提供了额外的安全性:

  • SELECT ... LOCK IN SHARE MODE

    在读取的任何行上设置共享模式锁定。其他会话可以读取行,但是在事务提交之前不能修改它们。如果这些行中的任何一个被尚未提交的另一个事务更改,则查询将等待直到该事务结束,然后使用最新值。

  • SELECT ... FOR UPDATE

    对于索引记录,搜索遇到的情况,锁定行和任何关联的索引条目,就像您UPDATE对这些行发出 语句一样。其他事务被阻止SELECT ... LOCK IN SHARE MODE在某些事务隔离级别更新这些行,执行操作或读取数据。一致的读取将忽略读取视图中存在的记录上设置的任何锁定。(记录的旧版本无法锁定;可以通过在记录的内存副本上应用撤消日志来重构它们 。)

这些子句在处理单个表或跨多个表的树结构或图结构数据时最有用。您从一处到另一处遍历边缘或树枝,同时保留返回的权利并更改这些“ 指针 ”值中的任何一个 。

提交或回滚事务时,将释放 由LOCK IN SHARE MODE和 设置的所有锁定FOR UPDATE。</

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值