当前位置:Gxlcms > 数据库问题 > 在mysql 中两种锁定问题

在mysql 中两种锁定问题

时间:2021-07-01 10:21:17 帮助过:5人阅读

; select info from father_table where name = nike LOCK IN SHARE MODE; insert into son_table values(SomeInfo); commit;

事务是确保多个进程的原子性, 但不能保证上述问题的正确性。在事务中,使用了LOCK IN SHARE MODE,
它在我们读取的行设置一个共享锁,这样就可读取最新数据了,同时,访问了一个同样有共享锁定的数据时,
则会等待该事务提交,之后再进行读取。这样就避免了一个事务未完成时,数据却被修改的问题。

2.实现一个计数器时,对同一字段进行修改,当两用户同时对其读取再修改时, 一个进程可能在
另一进程读数据和再次写数据中读取数据的情况,这样,就会遗漏一次统计。
办法:
1 . 先写数据,写数据加锁,且读数据也被限制,只有等数据加完,才能读取,而加完后,则是最新的数据。
2 .

begin;
select count form son_table FOR UPDATE;
update son_table set count = count + 1;
commit;

SELECT ... FOR UPDATE读最新的可见数据,在每个它读取的行设置独占锁定。因此,它设置与搜索的SQL UPDATE可能会在行上设置的锁定同样的锁定。

在mysql 中两种锁定问题

标签:

人气教程排行