MySQL浅问答(一)

事务


定义:
事务就是程序访问或更新数据库的执行单元,事务本身可能只有一条sql语句,也可能包含多条sql语句,但是事务必须满足ACID
事务的ACID:

①:原子性:事务的最小单位,具有不可分割的属性
②:一致性:事务的处理结果,要么一起完成,要么一起不完成,没有第三种形态
③:隔离性:一个事务的执行不会干扰到其他事务的执行
④:持久性:因为MySQL的数据是存储在硬盘中的,发生特殊情况下不易丢失数据


论述表级锁、行级锁以及乐观锁和悲观锁

表级锁

表级锁是MySQL中锁定粒度最大的一种锁,它表示只针对当前操作的表(数据)进行枷锁,因为是锁定粒度最大的,所以开销是最小的,而且,但是最容易发生锁冲突

行级锁

行级锁是MySQL中锁定粒度最细的一种锁,它表示只针对当前操作的行(数据)进行加锁。因为是锁定粒度最小的,所以也是最安全的,不过与之而来的是高并发、资源开销大等问题

乐观锁

将读写比作一个人一样,每次去修改数据都认为没人跟它抢资源,所以一般就是不上锁,但是在使用后会进行数据的前后比对

悲观锁

相对于乐观锁来说,悲观锁就是每次操作数据都认为有人跟它抢占资源,所以在每次访问资源之前都会进行加锁,等操作完了,在进行解锁

注意

①行级锁和表级锁都有共享锁排他锁
②MyISAM是一次性对数据全部加锁或者解锁,所以不会死锁,但是InnoDB是逐步加锁或者解锁所以容易死锁(解死锁另行参考)
③行级锁是锁索引的,而不是直接锁数据的


说出MyISAM 和 InnoDB 数据库引擎的区别

MyISAM引擎:是一种非事务性的引擎,提供高速存储和检索,以及全文搜索能力,适合数据仓库等查询频繁的应用,一个table实际保存为三个文件,.frm存储表定义,.MYD存储数据,.MYI存储索引

InnoDB引擎:是一种支持事务的引擎。给MySQL提供了具有提交,回滚和崩溃恢复能力的事务安全(ACID兼容)存储引擎,数据存储在一个或者多个数据文件中,支持类似于Oracle的锁机制

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值