• 数据库事务简介


    目录

    1.事务介绍

    2.考虑事务操作的步骤

    3.事务的ACID属性

    4.数据库并发的问题

    5.数据库的四种隔离级别

    6.Java代码设置数据库隔离级别


    1.事务介绍

    先看一个例子:A向B转账100元。这件事中涉及两个过程:A减少100元,B增加100元。但是我们可能会出现这样一种情况:A减少100元以后,由于网络或其他原因,B并没有增加100元,这时的结果显然与我们想要的结果不一致,也是不允许的。所以,我们需要保证两个过程要么都完成要么都不完成,这就是事务的一个例子。

    定义:数据库事务是一组逻辑操作单元,使数据从一种状态变成另一种状态。(一组逻辑操作就是一个或多个DML操作)

    事务处理原则:要保证所有事务都作为一个工作单位来执行,即便出现了故障,也不能改变这种执行方式。(要么所有数据都进行提交,要都都不进行提交,不能出现中间状态。)

    会进行数据提交的地方:①DDL操作②DML操作(可以通过setCommit来避免)③关闭数据库连接

    2.考虑事务操作的步骤

    同正常操作增删改操作相同,不过注意以下几点:

    ①在获取连接后要关闭自动提交。

    ②在所有数据写入以后在提交数据。

    ③发生错误时在中间状态进行回滚。

    ④保证最后才关闭连接。

    3.事务的ACID属性

    ①原子性:保证事务是一个不可分割的工作单位事务的操作要么都不发生,要么都发生。

    ②一致性:事务必须使数据库从一个一致性状态变成另一个一致性状态。

    ③隔离性:指一个事务的执行不能被其他事务干扰。

    ④永久性:一旦一个事务被提交,则其对数据库的改变是永久的。

    4.数据库并发的问题

    ①脏读:两个事务T1和T2,T1读取了T2修改但还未提交的数据,此时如果T2执行回滚操作,则T1读取到的数据是临时且无效的。

    ②不可重复读:两个事务T1和T2,T1读取了一个字段,然后T2将这个字段进行修改,T1再读取该字段时,读取的数据会和之前读取的内容不一样。

    ③幻读:两个事务T1和T2,T1从表中读取了一个字段,然后T2向表中添加几条数据,T1再次读取时会多出几行数据。

    5.数据库的四种隔离级别

    ①READ UNCOMMITTED:读未提交,三种问题都没有解决。

    ②READ COMMITTED:读以提交,解决了脏读问题。

    ③REPEATABLE READ:可重复读,解决了脏读和不可重复读问题。

    ④SERIALIZABLE:串行化,三种文字都解决了。 

    注意:Oracle默认是READ CMIMITED,MySQL默认是REPEATABLE READ

    6.Java代码设置数据库隔离级别

    获取当前连接的隔离级别:Connection对象的getTransactionIsolation()

    设置连接的隔离级别:Connection对象的setTransactionIsolation()

  • 相关阅读:
    Redis-cli 查询中文数据乱码问题
    【全志T113-S3_100ask】15-2 linux系统gpio模拟spi驱动屏幕——ILI9341
    c++学习之 继承的方式
    麒麟v10操作系统 安装docker
    2023MathorCup(妈妈杯) 数学建模挑战赛 解题思路
    LIRA: Learnable, Imperceptible and Robust Backdoor Attacks 论文笔记
    java 日志打印实体类时隐藏敏感字段不打印
    git2:git概述
    yolact ncnn保姆级源码解读(结合paper)
    TDengine学习(1):采集量(Metric),标签(label),数据采集点,表,超级表,子表、库
  • 原文地址:https://blog.csdn.net/m0_71987537/article/details/125599801