MySQL数据库中的事务机制与锁机制
问答题
1、答:
1、READ UNCOMMITTED(未提交读):
在此隔离级别中,事务中的修改即使没有提交,对其他事务也是可见的.事务可以读取未提交的数据,这也被称为脏读.
2、READ COMMITTED(提交读):
一个事务开始时,只能看见已经提交的事务所做的修改,也就是说,一个事务从开始到提交之前,所做的修改对其他事务都是不可见的.
这个级别也叫作不可重复读,因为两次执行相同的查询,得到的查询结果可能是不一样的.
3、REPEATABLE READ(可重复读):
此级别解决了脏读的问题,该级别保持了在同一个事务中多次查询的结果是相同的.但是此级别无法解决幻读,幻读就是当某个事务在读取某个范围的记录时,另外一个事务又在该范围内插入了新的记录,当之前的事务再次读取该范围的记录时,会产生幻行.MySql默认就是此隔离级别
4、SERIALIZABLE(可串行化):
此级别是最高的隔离级别.它通过强制事务串行执行,避免了前面说的幻读的问题.简单来说,SERIALIZABLE会在读取的每一行数据上都加锁,所以可能导致大量的超时和锁争的问题.实际应用中也会很少用到这个隔离级别.
2、答:
1、事务支持。innodb支持事务,而myisam强调的是性能,每次查询具有原子性,其执行数度比InnoDB类型更快,但是不提供事务支持。
2、表锁差异。myisam只支持表级锁,;innodb支持事务和行级锁,但是InnoDB的行锁,只是在WHERE的主键是有效的,非主键的WHERE都会锁全表的。
3、主键差异。MyISAM允许没有任何索引和主键的表存在,索引都是保存行的地址;而InnoDB如果没有设定主键或者非空唯一索引,就会自动生成一个6字节的主键(用户不可见),数据是主索引的一部分,附加索引保存的是主索引的值。
4、外键差异。MyISAM不支持外键,而innodb支持外键。
3、答:
在一次事务里面,多次查询之后,查询的结果集的个数不一致的情况叫做幻读。而多出来或者少的哪一行被叫做“幻读”。在Mysql中,可以采用“间隙锁”来解决幻读。
4、答:
1、死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。
2、产生的原因:
(1)互斥条件:进程要求对所分配的资源进行排它性控制,即在一段时间内某资源仅为一进程所占用。
(2)请求和保持条件:当进程因请求资源而阻塞时,对已获得的资源保持不放。
(3)不剥夺条件:进程已获得的资源在未使用完之前,不能剥夺,只能在使用完时由自己释放。
(4)环路等待条件:在发生死锁时,必然存在一个进程--资源的环形链。