mysql 锁定与实务处理分离水平

1.锁定:

    1.1》多个用户同时连接使用数据库是,如果没有些特殊的操作处理,很容易出现数据保存冲突的(就像在线购票系统)如下图演示冲突:

             

             用户a执行+40,同时用户b执行-40,如果没有特殊处理那么数据只会执行一个操作(b的操作-40,记过为60)。

     1.2》锁定含义:

                 就是是数据库中的特定数据不让其他用户操作而上的一把锁的机制,上锁为lock,解锁为unlock.

     1.3》锁定的种类:

                共享锁定:当用户参照数据时,将对象数据变为只读形式的锁定(该数据不能被改变,只能被参照)。上述图例中如果a对数据实施了共享锁定,那么b只能对

                                   数据进行参照,而不能更新。又称为读取锁定。

                排他锁定:是使用insert/update/delete命令对数据进行更新时使用的锁定。其他的进程(事物)一律不能对该数据读取。自然其他事物处理中也不能进行更新一集参照

                                   又称为,写入锁定或独占锁定。

     1.4》锁定粒度:

               含义:锁定对象的大小,单位通常被称为锁定的粒度。有以下三种(数据库不同会有所差异)1,记录(行),2,表,3,数据库。


2.分离水平

     2.1》 分离水平用来确定事务处理之间的影响程度(同时运行时相互影响的机制),分离水平越高,数据的整合性随之越高,但同时运行性下降。相反如果分离水平越低,数据整合性降低的同时,运行性提高了。根据数据的用途,分离水平的选择是开发人员必须判断或决定的。分离水平越高,维持锁定的时间久越长,这样同时运行性就会降低。增加死锁产生的概率。
分离水平读脏数据不可重复读产生幽灵数据
READ UNCOMMITTEDYYY
READ COMMITTEDNYY
REPEATEBLE READNNY
SERIALIZABLENNN

     2.2》详细介绍:set transaction isolation level 是用于修改分离水平的命令,如果制定了session关键字,设定只适用于当前的连接,(如果制定了global关键字,则使用与其后其它新连接)。

     2.2.1》read uncommitted(非提交读取)

     

             2.2.2》不可重复读取

             

          2.2.3》幻想读取

          

          2.2.4》:

          

 

3.死锁:

      

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值