由浅入深学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 Django中间件,中间件函数,全局异常处理操作示例

    Python中的Django框架是Web开发中常用的一种框架,其中的中间件是其实现功能的一个重要组成部分。本文将从中间件、中间件函数以及全局异常处理功能三个方面来详细讲解Python Django中间件的使用方法和实现原理,并通过示例代码进行说明。 1. Python Django中间件的概念和实现原理 中间件是Django框架中的一个重要组成部分,用于在处…

    python 2023年5月13日
    00
  • python 根据正则表达式提取指定的内容实例详解

    以下是详细讲解“Python根据正则表达式提取指定的内容实例详解”的完整攻略,包括正则表达式的基本语法、使用re模块提取指定内容的方法和两个示例说明。 正则表达式的基本语法 正则表达式是一种用于匹配文本的模式。Python中,我们可以使用re模块来处理正则表达式。正则表达式的基本语法如下: 字符:匹指定的字符。 字符集:匹配指定的字符集。 量词:匹配指的数量…

    python 2023年5月14日
    00
  • Python print函数:如何将对象打印输出

    Python的内置函数print()是用于将文本或其他对象输出到屏幕的方法。在Python中,print()函数有多种用法,可以用于输出字符串、数字、对象等,并可以通过一些参数进行格式化输出。 以下是使用print函数将对象打印输出的完整攻略: 标准格式 在Python中,使用print函数输出最基本的方式就是直接在括号中输入要输出的内容。 示例: prin…

    python 2023年6月3日
    00
  • Python实现将HTML转成PDF的方法分析

    在Python中,我们可以使用多种方法将HTML转换为PDF。以下是Python实现将HTML转成PDF的方法分析,包含两个示例。 方法1:使用pdfkit库将HTML转换为PDF pdfkit是一个Python库,用于将HTML文档转换为PDF格式。以下是一个示例,可以使用pdfkit将HTML文件转换为PDF文件: 步骤1:安装必要的库 在使用pdfki…

    python 2023年5月15日
    00
  • 写一个Python脚本自动爬取Bilibili小视频

    下面是Bilibili小视频自动爬取的攻略: 1. 所需工具 Python编程语言 requests:一个非常流行的Python HTTP客户端库,可用于向远程服务器发送HTTP/1.1请求。 BeautifulSoup:一个用于解析HTML和XML文档的Python库,可用于从网站上抽取所需的数据。 2. 步骤概述 2.1 分析目标网站 在开始编写Pyth…

    python 2023年5月14日
    00
  • 分享几道和「滑动窗口」有关的算法面试题

    作为一个算法面试题,滑动窗口通常用于解决字符串相关的问题。下面将为大家介绍两道和「滑动窗口」有关的算法面试题,分别是「最小覆盖子串」和「长度最小的子数组」,希望能够对大家有所帮助。 最小覆盖子串 该题中给定两个字符串 S 和 T,要求在字符串 S 中找到最小的覆盖子串,使得这个子串中包含了字符串 T 中的所有字符。 为了方便解题,我们可以使用两个哈希表来记录…

    python 2023年5月14日
    00
  • Python拼接字符串的7种方式详解

    以下是“Python拼接字符串的7种方式详解”的完整攻略。 1. 什么是字符串拼接 字符串拼接是指将多个字符串连接成一个字符串的操作。在Python中,字符串拼接多种方式,可以根据实际需求选择不同的方式。 2. 7种字符串拼接方式 2.1 使用加号(+)拼接字符串 # 使用加号(+)拼接字符串 str1 = "Hello" str2 = …

    python 2023年5月13日
    00
  • Python定义函数功能与用法实例详解

    Python定义函数功能与用法实例详解 简介 在Python中,函数是一组可重用的代码,用于执行特定的任务。通过定义函数,我们可以将大型代码拆分成具有明确功能的较小块,使代码更加模块化、可读性更高、可维护性更强。 定义函数时需要提供一些信息,例如名称、参数和代码块,使其能够被使用。在Python中,定义函数的语法如下: def function_name(p…

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