事务的四大特性(ACID)|学习笔记

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 快速学习事务的四大特性(ACID)

开发者学堂课程【JDBC数据库开发进阶:事务的四大特性(ACID)】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/32



目录:

 

l  事务

l  连接池

l  Threadlocal

l  Baseservlet自定义Servlet父类(只要求会用不要求会写)

l  DBUtils->commons->dbutils

 

事务

事务中需要完成的任务有:

1.事务的四大特性:ACID

2.MySQL中的操作事务

3.jabc中操作事务

而在MySQL中该如何操作事务?

事务其实是有两个端点的,分为事务的开始(start transaction)和结束(commit 表示提交事务或rollback 表示回滚事务,事务执行失败,回到原来的状态)

 

概述

 为了方便演示事务,我们需要创建一一个account表:。

CREATE TABLE account('

id INT PRIMARY KEY AUTO_ INCREMENT,

NAME VARCHAR(30),

balance NUMERIC(10.2)

);

INSERT INTO account(NAME,balanse) VALUES('zs', 100000);

INSERT INTO account(NAME,balance) VALUES('Is', 10000);

INSERT INTO account(NAME, balane) VALUES('ww', 10000);

 

SELECT * FROM account;

 

1.  什么是事务

举例:银行转账!张三转10000块到李四的账户,这其实是需要两条SQL语句

l  给张三的账户减去10000元;

l  给李四的账户加上10000元;

如果在第一条SQL语句执行后,在执行第二条SQL语句之前,程序被中断了(可能是抛出了某个异常,也可能是其他什么原因),那么李四的账户却没有加上10000元,而张三却被减去了10000元。这肯定是不行的!

   事务中的多个操作,要么完全成功,要么完全失败!不存在成功一半的情况!也就是说张三的账户减去10000元如果成功了,那么给李四的账户加上10000元的操作也必须是成功的,否则给张三减去10000元,以及给李四加上10000元都是失败的!

2.  事务的四大特性(ACID)

面试!

事务的四大特性是:

l  原子性(Atomicity):事务中所有操作是不可再分割的原子单位。事务中所有操作要么全部执行成功,要么全部执行失败。

l  一致性[11] (Consistency):事务执行后,数据库状态与其他业务规则保持一致。如转账业务,无论事务执行成功与否,参加转账的两个账号余额之和应该不变的。

隔离性(Isolation):隔离性是指在并发操作中,不同事务之间应该隔开来,使每个并发中的事务不会相互干扰。

l  持久性:(Durability):一旦事务提交成功,事务中所有的数据操作都必须被持久化到数据库中,即使提交事务后,数据库马上崩溃,在数据库重启时,也必须能保证通过某种机制恢复数据。

3.  MySQL中的事务

 在默认情况下,MySQL每执行一条SQL语句,都是一个单独的事务,如果需要在一个事务中包含多条SQL语句,那么需要开启事务和结束事务。

l  开启事务:start transaction

l  结束事务:commit或rollback(表示回滚事务,事务失败)

在执行SQL语句之前,先执行strat transaction,这就开启了一个事务(事务的起点),然后就可以去执行多条sQl语句,最后要结束事务,commit表示提交,即事务中的多条sQL语句所做出的影响会持久化到数握库中。或者rllback, 表示回滚,即回滚到事务的起点,之前做的所有操作都被撤消了!

image.png


 


批注:其他特性都是为了这一条服务的

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
SQL 关系型数据库 MySQL
事务的四大特性(ACID)|学习笔记
快速学习事务的四大特性(ACID)
111 0
事务的四大特性(ACID)|学习笔记
|
SQL 关系型数据库 MySQL
事务的四大特性(ACID)| 学习笔记
快速学习事务的四大特性(ACID)。
149 0
事务的四大特性(ACID)| 学习笔记
|
SQL Oracle 关系型数据库
事务的四大特性
事务的四大特性(原子性、一致性、隔离性、持久性)
186 1
|
数据库
ACID--事务四大特性
ACID,指的是在数据库事务正确执行的四个基本要素的缩写。 具体解释:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)。
1640 0
|
数据库
数据库事务的四大特性
事务的4大特性(ACID): 原子性(Atomicity): 事务是数据库的逻辑工作单位,它对数据库的修改要么全部执行,要么全部不执行。 一致性(Consistemcy): 事务前后,数据库的状态都满足所有的完整性约束。
|
关系型数据库 MySQL Java
事务的四大特性和隔离级别
本篇讲诉数据库中事务的四大特性(ACID),并且将会详细地说明事务的隔离级别。   如果一个数据库声称支持事务的操作,那么该数据库必须要具备以下四个特性: ⑴ 原子性(Atomicity)   原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,这和前面两篇博客介绍事务的功能是一样的概念,因此事务的操作如果成功就必须要完全应用到数据库,如果操作失败则不能对数据库有任何影响。
1224 0
|
存储 关系型数据库 MySQL
事务的 ACID 特性|学习笔记
快速学习事务的 ACID 特性
|
数据库
分布式事务的四大特性和隔离级别
分布式事务是指在分布式系统中执行的涉及多个数据库或资源的事务。由于分布式环境中存在网络故障、节点故障等不可靠因素,因此需要采取一定的机制来保证分布式事务的一致性和可靠性。
448 0
|
关系型数据库 MySQL Java
数据库事务的四大特性以及事务的隔离级别
数据库事务的四大特性以及事务的隔离级别http://www.bieryun.com/3118.html 本篇讲诉数据库中事务的四大特性(ACID),并且将会详细地说明事务的隔离级别。 如果一个数据库声称支持事务的操作,那么该数据库必须要具备以下四个特性: ⑴ 原子性(Atomicity) 原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,这和前面两篇博客介绍事务的功能是一样的概念,因此事务的操作如果成功就必须要完全应用到数据库,如果操作失败则不能对数据库有任何影响。
1574 0
|
数据库
数据库事物四大特性-ACID
事务的:原子性、一致性、分离性、持久性   事物(transaction)是由一些列操作序列构成的执行单元,这些单元要么都做,要么不做,是一个不可分割的工作单元。数据库事物的四个基本性质(ACID)1.原子性(Atomicity)  指的是事物中包含的所有操作要么全做,要么全不做(all or none)。
989 0

热门文章

最新文章