数据库锁之MYSQL表锁行锁与排他锁和共享锁(写锁)排它锁(读锁)的理解

一、为什么要对数据库加锁?

             保证数据库数据的安全(不脏读、漏读)

二、数据库锁的概念理解     

         1.1、按照锁的类型划分为

                       1、共享锁(读锁)

                                       共享锁就是多个事务对于同一数据可以共享一把锁,都能访问到数据,但是只能读不能修改。

                       2、排他锁(写锁)

                                       如果一个事务获取了一个数据行的排他锁,其他事务就不能再获取该行共享锁和排他锁

                                 只有获取到排它锁的事务支持对数据行的修改。

         1.2、按照锁的范围来划分为

                      1、行锁

                                    MySQL 5.6 以后Engine db 默认是行锁,当然Engine也支持表锁,mysql InnoDB引擎默认的修改数据语                                  句,update,delete,insert都会自动给涉及到的数据加上排他锁,select语句默认不会加任何锁类型,

                      2、表锁

                                   MySQL  的MyISAM 的默认锁为表锁,当数据库表设置为MyISAM后,操作该数据库都会加表锁,

                            其中 查询数据会加读锁(共享锁),修改、增加、删除数据会加写锁(排他锁)

                             

 

        四、读锁和写锁的用法

                     1、如果加排他锁可以使用select ...for update语句,

                     2、加共享锁可以使用select ... lock in share mode语句。

                     3、加表锁


//给订单表(orders)加读锁
LOCK tables orders read local;
//读锁释放
Unlock tables;

 

            

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值