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/8f66f/8f66f83b46b4a2a01f99587cbadeee3bf150f801" alt=""
(续)
data:image/s3,"s3://crabby-images/294bf/294bf720a7a013f65e7450c16ab5c9e60d85086b" alt=""
1.Oracle中的事务隔离级别
Oracle数据库支持Read Committed(提交读)和Serializable(可串行化)这两种事务隔离级别,提交读是Oracle数据库默认的事务隔离级别,Oracle不支持脏读。SYS用户不支持Serializable(可串行化)隔离级别。
Oracle可以设置的隔离级别有:
data:image/s3,"s3://crabby-images/555bd/555bd4bdaf60daee45b0d1cea988b6f5a710df5b" alt=""
Oracle数据库查询当前会话的事务隔离级别的SQL语句为:
data:image/s3,"s3://crabby-images/625b2/625b20064b2324dfdf15d269bd8d2b5f38cb56be" alt=""
Oracle中使用如下脚本可以开始一个事务:
data:image/s3,"s3://crabby-images/b617d/b617dfd5a8d1d40b547a593d3cd17557158d37f8" alt=""
示例如下:
data:image/s3,"s3://crabby-images/7d811/7d8115288804437e489dc5c726cf69d7f23a250f" alt=""
data:image/s3,"s3://crabby-images/17f7e/17f7e24546fd7d9780e252bab481bf2e67b9ca9c" alt=""
2.MySQL中的事务隔离级别
MySQL数据库支持Read Uncommitted(未提交读)、Read Committed(提交读)、Repeatable Read(可重复读)和Serializable(可串行化)这4种事务隔离级别,其中,Repeatable Read(可重复读)是MySQL数据库的默认隔离级别。
MySQL可以设置的隔离级别有(其中,GLOBAL表示系统级别,SESSION表示会话级别):
data:image/s3,"s3://crabby-images/5f5a2/5f5a2846633aa74216716bde7b83e8a2d3565093" alt=""
data:image/s3,"s3://crabby-images/9fe87/9fe87557cbcd2a024cf29d1d67f7c5bfe0aca27e" alt=""
MySQL数据库查询当前会话的事务隔离级别的SQL语句为:
data:image/s3,"s3://crabby-images/93bd4/93bd4be2429908f8d95a7a2d950c3899433d45d1" alt=""
MySQL数据库查询系统的事务隔离级别的SQL语句为:
data:image/s3,"s3://crabby-images/bacdb/bacdbdaf709874c225c616f732bb307e8084b8e2" alt=""
当然,也可以同时查询:
data:image/s3,"s3://crabby-images/d3867/d386790d21ca871f2dad79f1b85f1dac9d853b9e" 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/f6bc0/f6bc0b6cd5ca8117b058872356ece5646681e31b" alt=""
SQL Server可以设置的隔离级别有:
data:image/s3,"s3://crabby-images/f8558/f855825ccb232191356cf89c1b3f48c971ba2ae6" alt=""