mysql支持多用户同时读写吗

mysql支持多用户同时读写吗,第1张

数据库是支持多用户访问的,因此需要一种机制保证多个用户同时读取和修改数据时,数据不会被破坏或者失效。在MySQL中,使用锁来保证并发连接情况下的数据准确性。

InnoDB中的锁定技术往往是基于索引实现的,如果SQL中没有利用到索引的话,往往会执行全表扫描,触发表锁。所以从效率上来说,我们应该建立合适的索引,减少锁的数据行提高并发。

从锁的粒度上来说,可以将锁分为表锁和行锁;我们主要讨论行锁的应用。

从行锁的角度上来说,InnoDB存储引擎实现了两种标准的行级锁,共享锁(读锁)和排他锁(写锁)。

共享锁:当一个事务获取了某行数据的共享锁后,其他事务依然可以对这行数据加共享锁,但是不能加排他锁。

排他锁:当一个事务获取了某行数据的排他锁后,其他事务不可以对这行数据加任何锁。

从锁的范围来说,行锁还可以分成record lock、gap lock、next-key lock。

record lock:索引的记录锁,是建立在索引记录上的,如果没有索引的情况,往往会触发表锁。

gap lock:加在索引记录间隙上的锁。

next-key lock:record lock+gap lock的组合,用来在RR级别解决幻读的问题;所以通常在insert时,会锁定相邻的键。

回答于 2 小时前

看看并发数够不够,然后看看超时值是不是设置过大,还有每个客户Duan *** 作完成后要关闭连接

这些都没问题的话,那就得看看 *** 作的是什么内容了,如果只是读取表,应该都可以读取的,但如果是修改表,而且是同一张表,那最好要在其他临时表中搞个键值来锁定,一次只能 *** 作一台机,其他机等待!

DECLARE A INT

SET A=5 --赋值修改A就行了

update game set ct_lvneed=ct_lvneed/2 where ct_num=A

update game set ct_lvneed=ct_lvneed/3 where ct_num=A

update game set ct_lvneed=ct_lvneed/4 where ct_num=A

update game set ct_lvneed=ct_lvneed/5 where ct_num=A


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7671213.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-08
下一篇 2023-04-08

发表评论

登录后才能评论

评论列表(0条)

保存