事务


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

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


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

表级锁

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

行级锁

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

乐观锁

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

悲观锁

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

注意

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


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

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

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