zoukankan      html  css  js  c++  java
  • 数据库隔离级别

    隔离级别(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;
    
     
  • 相关阅读:
    python flsak 框架
    postman
    压力测试和负载测试
    软件测试相关内容
    Linux常用基本命令
    leetcode刷题——反转字符串
    leetcode——搜索插入位置
    leetcode刷题——移除元素
    leetcode 刷题 ——删除排序数组中的重复项
    json.decoder.JSONDecodeError: Expecting value 错误的处理
  • 原文地址:https://www.cnblogs.com/wangyonglong/p/7597013.html
Copyright © 2011-2022 走看看