由浅入深学MySQL之事务全攻略

前言

从今天开始本系列就带各位小伙伴学习数据库技术。数据库技术是Java开发中必不可少的一部分知识内容。也是非常重要的技术。本系列教程由浅入深, 全面讲解数据库体系。 非常适合零基础的小伙伴来学习。


全文大约 【1707】 字,不说废话,只讲可以让你学到技术、明白原理的纯干货!本文带有丰富案例及配图,让你更好的理解和运用文中的技术概念,并可以给你带来具有足够启迪的思考...

一. 事务

事务这个概念不太容易理解,所以我们通过下面一个模拟转账的案例来让各位小伙伴理解事务到底是什么

1. 模拟转账

生活当中转账是转账方账户扣钱,收账方账户加钱。我们用数据库操作来模拟现实转账。

举个栗子: 数据库模拟转账。

#A 账户转账给 B 账户 1000 元。
#A 账户减1000 元
UPDATE account SET MONEY = MONEY-1000 WHERE id=1;

#B 账户加 1000 元
UPDATE account SET MONEY = MONEY+1000 WHERE id=2;

上述代码完成了两个账户之间转账的操作。

举个栗子: 模拟转账错误。

#A 账户转账给 B 账户 1000 元。
#A 账户减1000 元
UPDATE account SET MONEY = MONEY-1000 WHERE id=1;
#断电、异常、出错...

#B 账户加 1000 元
UPDATE account SET MONEY = MONEY+1000 WHERE id=2;

上述代码在减操作后过程中出现了异常或加钱语句出错,会发现,减钱仍旧是成功的,而加钱失败了!

注意: 每条 SQL 语句都是一个独立的操作,一个操作执行完对数据库是永久性的影响。

2. 事务的概念

事务是一个原子操作。是一个最小执行单元。可以由一个或多个SQL语句组成,在同一个事务当中,所有的SQL语句都成功执行时,整个事务成功,有一个SQL语句执行失败,整个事务都执行失败。

各位小伙伴是否理解了呢?那么我们再做个小小的总结:

事务就是让多个操作形成一个整体,在这个整体中的多个操作要么执行全成功,要么执行全失败。这就是事务的作用。

3. 事务的执行过程

开始过程:连接到数据库,执行一条DML语句。 上一个事务结束后,又输入了一条DML语句,即事务的开始。

结束过程如下:

1).提交:

a.显示提交:commit;

b.隐式提交:一条创建、删除的语句,正常退出(客户端退出连接)。

2).回滚:

a.显示回滚:rollback;

b.隐式回滚:非正常退出(断电、宕机),执行了创建、删除的语句,但是失败了,会为这个无效的语句执行回滚。

4. 事务的原理

数据库会为每一个客户端都维护一个空间独立的缓存区(回滚段),一个事务中所有的增删改语句的执行结果都会缓存在回滚段中,只有当事务中所有SQL语句均正常结束(commit),才会将回滚段中的数据同步到数据库。否则无论因为哪种原因失败,整个事务将回滚(rollback)。

5. 事务的特性

下面给各位小伙伴系统的说一下事务都具有哪些特性和功能。

通常叫做ACID原则,因为ACID是由下面四个单词的首字母构成的。

Atomicity(原子性): 表示一个事务内的所有操作是一个整体,要么全部成功,要么全部失败

Consistency(一致性) :表示一个事务内有一个操作失败时,所有的更改过的数据都必须回滚到修改前状态

Isolation(隔离性): 事务查看数据操作时数据所处的状态,要么是另一并发事务修改它之前的状态,要么是另一事务修改它之后的状态,事务不会查看中间状态的数据。

Durability(持久性): 持久性事务完成之后,它对于系统的影响是永久性的。

6. 事务应用

应用环境:基于增删改语句的操作结果(均返回操作后受影响的行数),可通过程序逻辑手动控制事务提交或回滚。

举个栗子: 事务完成转账,A账户给B账户转账。

#1.开启事务
START TRANSACTION;|setAutoCommit=0;#禁止自动提交 setAutoCommit=1;#开启自动提交
#2.事务内数据操作语句
UPDATE ACCOUNT SET MONEY = MONEY-1000 WHERE ID = 1;
UPDATE ACCOUNT SET MONEY = MONEY+1000 WHERE ID = 2;
#3.事务内语句都成功了,执行 COMMIT;
COMMIT;
#4.事务内如果出现错误,执行 ROLLBACK;
ROLLBACK;

注意: 开启事务后,执行的语句均属于当前事务,成功再执行 COMIIT,失败要进行 ROLLBACK。

二. 结语

最后在这里对本文核心要点进行总结:

  1. 事务能够在增删改操作中保证数据的一致性,所以在增删改操作中必须加入事务。

  2. 各位小伙伴一定要熟练的记住事务的操作过程以及ACID原则,非常重要哦。

原文链接:https://www.cnblogs.com/qian-fen/p/17385366.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:由浅入深学MySQL之事务全攻略 - Python技术站

(0)
上一篇 2023年5月9日
下一篇 2023年5月9日

相关文章

  • python tkinter实现弹窗的输入输出

    下面是Python tkinter实现弹窗的输入输出的完整攻略。 简介 Tkinter是Python标准库中用于快速创建图形界面的模块之一,通过使用Tkinter,可以快速地创建窗体、标签、按钮等GUI元素。在Tkinter中,弹窗是一种用于输入输出的常见元素,在实际开发中很有用。下面将介绍如何使用Python tkinter实现弹窗的输入输出。 输入弹窗 …

    python 2023年6月5日
    00
  • python 巧用正则寻找字符串中的特定字符的位置方法

    以下是“Python巧用正则寻找字符串中的特定字符的位置方法”的完整攻略: 一、问题描述 在Python中,我们可以使用正则表达式寻找字符串中的特定字符的位置。本文将详细讲解如何使用Python正则表达式寻找字符串中的特定字符的位置,并提供两个示例说明。 二、解决方案 2.1 使用正则表达式寻找字符串中的特定字符的位置 在Python中,我们可以使用正则表达…

    python 2023年5月14日
    00
  • Python实现的凯撒密码算法示例

    以下是关于“Python实现的凯撒密码算法示例”的完整攻略: 简介 凯撒密码是一种简单的加密算法,它通过将明文中的每个字母按照一定的偏移量进行替换,从而得到密文。在本教程中,我们将介绍如何使用Python实现凯撒密码算法,并提供两个示例说明。 实现凯撒密码算法 以下是使用Python实现凯撒密码算法的代码: def caesar_cipher(text, s…

    python 2023年5月14日
    00
  • Python的另外几种语言实现

    Python语言有多种实现,其中比较常见的有CPython、Jython、IronPython、PyPy等。它们都是通过不同的方式来实现Python语言的解释器和编译器,具有各自的特点和适用场景。 CPython CPython是官方Python实现,也是Python编程语言的标准实现。它是使用C语言开发的解释器,可以在Unix/Linux、Windows、…

    python 2023年5月19日
    00
  • 使用Python将语音转换为文本的方法

    关于Python进行语音转文本有许多库可以选择,下面将介绍其中的两个库——SpeechRecognition和pocketsphinx。其中的pocketsphinx是CMU Sphinx的轻量版,是一个C语言的语音解码器引擎,也是一个被广泛使用的语音识别引擎。SpeechRecognition则是一款基于Python的语音识别库,可以调用不同的语音识别AP…

    python 2023年6月6日
    00
  • 解决django model修改添加字段报错的问题

    如果在 Django 项目中已经存在的模型上添加或者修改字段,可能会遇到错误。这通常发生在运行 makemigrations 或 migrate 命令时出现。 通常在添加或修改模型的字段时,需要指定字段的类型和相关的属性。可能因为这些属性不兼容或者不一致,导致 Django 无法自动创建或更新数据表。 下面是解决 Django 模型修改添加字段报错的方法,可…

    python 2023年5月20日
    00
  • Python实现替换文件中指定内容的方法

    下面是Python实现替换文件中指定内容的方法的完整攻略。 一、需求背景 有时候我们需要在一个文件中替换指定的字符串,比如我们需要把文件中的”a”字符串替换成”b”字符串。Python提供了操作文件的API,可以用Python来实现这个需求。 二、操作步骤 1.打开文件 使用Python的内置函数open()打开文件,并指定打开文件的模式为”r”,表示只读模…

    python 2023年6月5日
    00
  • python+requests接口自动化框架的实现

    以下是关于Python+requests接口自动化框架的实现: Python+requests接口自动化框架的实现 requests是Python中一个流行的HTTP库,可以用于向Web服务器发送HTTP请求和接响应。结合Python的unittest测试框架,可以实现接口自动化测试。以下是Python+requests接口自动化框架的实现: 安装reque…

    python 2023年5月14日
    00
合作推广
合作推广
分享本页
返回顶部