data:image/s3,"s3://crabby-images/0afba/0afba2fad6e82f139336e4e66e53b81051174ae7" alt="MySQL程序员面试笔试宝典"
4.6 Oracle、MySQL和SQL Server中的事务隔离级别分别有哪些?
Oracle、MySQL和SQL Server中的事务隔离级别参考下表:
data:image/s3,"s3://crabby-images/e5510/e5510d2235e7713fbe6b6406d6ade22efba00a2d" alt=""
(续)
data:image/s3,"s3://crabby-images/cf1c6/cf1c6b972d1d923da60584d47182c71579fd71dd" alt=""
1.Oracle中的事务隔离级别
Oracle数据库支持Read Committed(提交读)和Serializable(可串行化)这两种事务隔离级别,提交读是Oracle数据库默认的事务隔离级别,Oracle不支持脏读。SYS用户不支持Serializable(可串行化)隔离级别。
Oracle可以设置的隔离级别有:
data:image/s3,"s3://crabby-images/479e2/479e2c7d0faf8d8a600aefbff24702aa88a467cc" alt=""
Oracle数据库查询当前会话的事务隔离级别的SQL语句为:
data:image/s3,"s3://crabby-images/6bc6e/6bc6e443c8f4c9bc3f516d34bab3315cf5972c0c" alt=""
Oracle中使用如下脚本可以开始一个事务:
data:image/s3,"s3://crabby-images/4a231/4a231262b8d0e069e874b52292a67daa347993d5" alt=""
示例如下:
data:image/s3,"s3://crabby-images/429ab/429abedad1f1a904328228e83dc6ad5de21da29d" alt=""
data:image/s3,"s3://crabby-images/4d5a6/4d5a6d949741ea68f833aba3414b82bc319f4174" alt=""
2.MySQL中的事务隔离级别
MySQL数据库支持Read Uncommitted(未提交读)、Read Committed(提交读)、Repeatable Read(可重复读)和Serializable(可串行化)这4种事务隔离级别,其中,Repeatable Read(可重复读)是MySQL数据库的默认隔离级别。
MySQL可以设置的隔离级别有(其中,GLOBAL表示系统级别,SESSION表示会话级别):
data:image/s3,"s3://crabby-images/794de/794de1466d77458f3f3e6ced12834dcdd77fc6ae" alt=""
data:image/s3,"s3://crabby-images/56a54/56a5415fbfee8d5f512725017b211c3be431d9db" alt=""
MySQL数据库查询当前会话的事务隔离级别的SQL语句为:
data:image/s3,"s3://crabby-images/e9f27/e9f274dbf7f4028e3088e046dcca91938b3dc39f" alt=""
MySQL数据库查询系统的事务隔离级别的SQL语句为:
data:image/s3,"s3://crabby-images/87300/87300a3651c41fafc924ab418407cbc3abf329f8" alt=""
当然,也可以同时查询:
data:image/s3,"s3://crabby-images/a8a7d/a8a7d5694c2781da3a84d6b27cb5c0f88495c310" alt=""
3.SQL Server中的事务隔离级别
SQL Server共支持6种事务隔离级别,分别为:Read Uncommitted(未提交读)、Read Committed(提交读)、Repeatable Read(可重复读)、Serializable(可串行化)、Snapshot(快照)、Read Committed Snapshot(已经提交读隔离)。SQL Server数据库默认的事务隔离级别是Read Committed(提交读)。
获取事务隔离级别:
data:image/s3,"s3://crabby-images/67d42/67d423f8d90d7d85d60041571a241c2136f41ff6" alt=""
SQL Server可以设置的隔离级别有:
data:image/s3,"s3://crabby-images/6b647/6b6475c519300a59bba05d77daa62c89e596a72c" alt=""