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/b4a2c/b4a2c736dce77a9a9fbc55c9d339235514bcc3a7" alt=""
(续)
data:image/s3,"s3://crabby-images/29191/291910c6705b06e5911781dcb43fa795936e146c" alt=""
1.Oracle中的事务隔离级别
Oracle数据库支持Read Committed(提交读)和Serializable(可串行化)这两种事务隔离级别,提交读是Oracle数据库默认的事务隔离级别,Oracle不支持脏读。SYS用户不支持Serializable(可串行化)隔离级别。
Oracle可以设置的隔离级别有:
data:image/s3,"s3://crabby-images/9b88a/9b88a3294e8c4c7fca3426bd7d7f27aed5d0304a" alt=""
Oracle数据库查询当前会话的事务隔离级别的SQL语句为:
data:image/s3,"s3://crabby-images/a9c7f/a9c7f8784c32b3da9a5cb7e238f83186b7b055f9" alt=""
Oracle中使用如下脚本可以开始一个事务:
data:image/s3,"s3://crabby-images/5f4e6/5f4e6cbba9c0ff7038e32d1e0b95a98636bbab91" alt=""
示例如下:
data:image/s3,"s3://crabby-images/1cb8d/1cb8df77073b1668a36eea4c920ad4fbf49b4352" alt=""
data:image/s3,"s3://crabby-images/a6149/a61498931d419acba150582be25064b12b5cade7" alt=""
2.MySQL中的事务隔离级别
MySQL数据库支持Read Uncommitted(未提交读)、Read Committed(提交读)、Repeatable Read(可重复读)和Serializable(可串行化)这4种事务隔离级别,其中,Repeatable Read(可重复读)是MySQL数据库的默认隔离级别。
MySQL可以设置的隔离级别有(其中,GLOBAL表示系统级别,SESSION表示会话级别):
data:image/s3,"s3://crabby-images/2c4c6/2c4c6d5f2a0e6e45a8a1a54782032453cd542065" alt=""
data:image/s3,"s3://crabby-images/fc8d8/fc8d8c251e73ca5a2bde9524adbe8e3f0f8f8a8f" alt=""
MySQL数据库查询当前会话的事务隔离级别的SQL语句为:
data:image/s3,"s3://crabby-images/993dd/993ddbc452ffdcfb60f1a884a138c66d8bc5506b" alt=""
MySQL数据库查询系统的事务隔离级别的SQL语句为:
data:image/s3,"s3://crabby-images/db763/db763fd0eaf91d32e15063cd437a3acf502d5d1e" alt=""
当然,也可以同时查询:
data:image/s3,"s3://crabby-images/46db2/46db22e31294b6087f7d0f3c65abf602781be6d5" 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/3555c/3555ca72eb749df0896fb54b3dc6b3c19b55f18c" alt=""
SQL Server可以设置的隔离级别有:
data:image/s3,"s3://crabby-images/a1c59/a1c59061eb582e4cf438a08dfabddbe88b626916" alt=""