数据库隔离级别

本文详细介绍了数据库事务的四种隔离级别:未提交读、提交读、重复读和序列化,并解释了每种级别下可能出现的问题,如脏读、非重复读和幻象读等。此外还提供了ORACLE和MySQL中设置隔离级别的具体方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

隔离级别(isolation level):定义了事务与事务之间的隔离程度,隔离级别与并发性是互为矛盾的:
    隔离程度越高,数据库的并发性越差;隔离程度越低,数据库的并发性越好。
ANSI/ISO SQL92标准定义了一些数据库操作的隔离级别:
1.未提交读(read uncommitted)脏读
2.提交读(read committed)非重复读
3.重复读(repeatable read)幻像
4.序列化(serializable)
通过一些现象,可以反映出隔离级别的效果。这些现象有:
1.更新丢失(lost update):当系统允许两个事务同时更新同一数据是,发生更新丢失。
2.脏读(dirty read):当一个事务读取另一个事务尚未提交的修改时,产生脏读。
3.非重复读(nonrepeatable read):同一查询在同一事务中多次进行,由于其他提交事务所做的修改或删除,
    每次返回不同的结果集,此时发生非重复读。(A transaction rereads data it has previously read and 
    finds that another committed transaction has modified or deleted the data. )
4.幻像(phantom read):同一查询在同一事务中多次进行,由于其他提交事务所做的插入操作,每次返回不同
    的结果集,此时发生幻像读。(A transaction reexecutes a query returning a set of rows that satisfies 
    a search condition and finds that another committed transaction has inserted additional rows that satisfy the condition. )
                    Dirty Read        NonRepeatable Read        Phantom Read
Read uncommitted    Possible        Possible                Possible
Read committed        Not possible    Possible                Possible
Repeatable read        Not possible    Not possible            Possible
Serializable        Not possible    Not possible            Not possible
------------------------------------------------------------------------------------------------------------------------------
ORACLE提供了SQL92标准中的read committed和serializable,同时提供了非SQL92标准的read-only。
ORACLE缺省的事务隔离级别:read committed
---------------------------------------------------------------------------------------------------------------------
mysql:
修改隔离级别:
    set session|global transaction isolation level read uncommitted;//(Read uncommittedRead committedRepeatable readSerializable)
查看隔离级别:
    select @@tx_isolation;
    select @@global.tx_isolation;
修改事务非自动提交:
    set autocommit=off;  
查看事务提交机制:
    select @@autocommit; 
查看数据表里的锁:
    select * from information_schema.innodb_locks;
开启事务:
    start transaction; 或
    begin;

 

 

转载于:https://www.cnblogs.com/wangyonglong/p/7597013.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值