MYSQL进阶学习笔记九:MySQL事务的应用!(视频序号:进阶_21-22)

知识点十:MySQL 事务的应用 (21-22)

  为什么要引入事务:

     为什么要引入事务这个技术呢?现在的很多软件都是多用户,多程序,多线程的。对同一表可能同时有很多人在用,为保持数据的一致性,所以提出了事务的概念。这样很抽象,举个例子:

      A给B要划钱,A的账户是-1000元,B的账户是+1000元,这两个UPDATE语句必须作为一个整体来执行,不然A扣钱了,B没有加钱这种情况很难处理。

  什么存储过程类型支持事务:

     1.查看数据库下面支持的事务(InnoDB支持):

 SHOW ENGINES;

     2.查看MySQL当前默认存储引擎:

SHOW VARIABLES LIKE ‘%storage_engine%’;

     3.查看某张表的存储引擎:

SHOW CREATE TABLE tbl_name;

     4.对于表的存储结构的修改:

建立InnoDB表: CREATE TABLE … type=InnoDB;
修改表的存储引擎:ALTER TABLE tbl_name type=InnoDB;

  如何创建事务:

 1 CREATE DATABASE bank;
 2 USE bank;
 3 CREATE TABLE account(
 4 aid int NOT NULL,
 5 accname VARCHAR(20) NOT NULL,
 6 accmoney DECIMAL(20,2) NOT NULL,
 7 PRIMARY KEY(aid)
 8 ) ENGINE=InnoDB DEFAULT CHARSET=gbk;
 9
10 INSERT INTO account VALUES(1,‘A‘,4000),
11 (2,‘B‘,4000);

默认数据

    创建事务的语法:

      1. 开启事务start transaction,可以简写为 begin (注意:start transaction会造成一个隐含的UNLOCK TABLES执行)
      2. 然后记录之后需要执行的一组sql
      3. 提交commit
      4. 如果所有的sql都执行成功,则提交,将sql的执行结果持久化到数据表内。
      5. 回滚rollback
      6. 如果存在失败的sql,则需要回滚,将sql的执行结果,退回到事务开始之时
      7. 无论回滚还是提交,都会关闭事务!需要再次开启,才能使用。
      8. 还有一点需要注意,就是事务只针对当前连接。

    事务的提交:

      基本原理:      

        提交,就会将结果持久化,不提交就不会。

        如果我们不开启事务,只执行一条sql,马上就会持久化数据,可以看出,普通的执行就是立即提交。
        这是因为mysql默认对sql语句的执行是自动提交的

        也就是说,开启事务,实际上就是关闭了自动提交的功能,改成了commit手动提交!

        我们可以通过简单的对是否自动提交加以设置,完成开启事务的目的!
        自动提交的特征是保存在服务的一个autocommit的变量内。可以进行修改:

SET autocommit=0;

        说明:

          可以控制的事务行为称为AUTOCOMMIT设置会话变量。
          如果AUTOCOMMIT设置为1(默认值),然后每一个SQL语句(在事务与否)被认为是一个完整的事务,并承诺在默认情况下,当它完成。
          AUTOCOMMIT设置为0时,发出SET AUTOCOMMIT =0命令,在随后的一系列语句的作用就像一个事务,直到一个明确的COMMIT语句时,没有活动的提交。

        还需要注意一点,就是事务类似于外键约束,只被innodb引擎支持。       

        补充:

commit and chain:表示提交事务之后重新开启了新的事务。
rollback and release:表示事务回滚之后断开和客户端的连接。

 1 --启动事务
 2 start transaction;
 3 --提交事务
 4 commit;
 5
 6 --启动两个进程查看情况
 7 SET autocommit=0;
 8 start transaction;
 9 UPDATE account SET accmoney=accmoney-1000 WHERE aid=1;
10 UPDATE account SET accmoney=accmoney+1000 WHERE aid=2;
11 COMMIT;
12
13 SET autocommit=1;
14 UPDATE account SET accmoney=accmoney-1000 WHERE aid=1;

事务的提交测试

    事务的回滚:

      回到事务发生之前的数据状态。通常rollback。

      还原测试点:

 1 start transaction;
 2 UPDATE account SET accmoney=2000 WHERE aid=1;
 3 rollback;
 4
 5 start transaction;
 6 UPDATE account SET accmoney=7000 WHERE aid=1;
 7 commit and chain;
 8
 9
10 --还原点测试
11 SET autocommit=0;
12 INSERT INTO account VALUES(3,‘test1‘,5000);
13 savepoint s1;
14 INSERT INTO account VALUES(4,‘test2‘,6000);
15 savepoint s2;
16 INSERT INTO account VALUES(5,‘test3‘,7000);
17 savepoint s3;
18 --执行完三个插入语句,SELECT * FROM account可以看到这这三条数据,如果你想回滚到最初
19 --rollback就是最初什么都没有的状态。如果你想回到savepoint s1的状态(也就是插入一条test1那里)
20 --rollback to savepoint s1,同理什么都可以做.
21 rollback to savepoint s2;

事务的回滚和还原点测试  

总结事务:

  事务应该具有4个属性,原子性,一致性,隔离性,持久性。这四个属性通常称为ACID特性:

    原子性(atomicity):一个事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么不做。

    一致性(consistency):事务必须是使数据库从一个一致性状态变成另一个一致性状态。一致性与原子性使密切相关的。

    隔离性(isolation):一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。

    持久性(durability):持久性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。

原文地址:https://www.cnblogs.com/darwinli/p/9057582.html

时间: 2024-10-29 10:45:57

MYSQL进阶学习笔记九:MySQL事务的应用!(视频序号:进阶_21-22)的相关文章

MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类

首先需要回顾一下上一篇文章中的内容:MySQL数据库学习笔记(九)----JDBC的PreparedStatement接口重构增删改查 一.JDBC事务处理: 我们已经知道,事务的概念即:所有的操作要么同时成功,要么同时失败.在MySQL中提供了Commit.Rollback命令进行事务的提交与回滚.实际上在JDBC中也存在事务处理,如果要想进行事务处理的话,则必须按照以下的步骤完成. JDBC中事务处理的步骤: 1.要取消掉JDBC的自动提交:void setAutoCommit(boolea

Mysql Cookbook学习笔记第二章

1,使用python链接mysql + ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 # -*- coding: utf-8 -*- # connect.py --连接到MySQL服务器 import sys import MySQLdb try:     conn = MySQLdb.connect(db = "cookbook",                            host = "localhost"

MySQL学习笔记之一 MySQL入门

本人之前接触的关系型数据库主要是oracle和sqlserver,而对于mysql知之甚少,但查阅网上资料发现,mysql与oracle非常相似,所以学起来应该不会很费劲,在总结的时候可能更多的把关注点放在它与oracle的不同之处. 一.简介 MySQL是一个真正的多用户.多线程SQL数据库服务器.SQL(结构化查询语言)是世界上最流行的和标准化的数据库语言.MySQL是一个客户端/服务器结构的实现, 它由一个服务器守护程序mysqld和很多不同的客户程序和库组成. MySQL的普及并不局限于

MYSQL数据库学习笔记1

MYSQL数据库学习笔记1 数据库概念 关系数据库 常见数据库软件 SQL SQL的概念 SQL语言分类 数据库操作 创建数据库 查看数据库的定义 删除数据库 修改数据库 创建表 数据类型 约束 修改表 表的增删查改 查询 数据库概念 数据库是一种对大量信息进行管理的一种方法. 数据库系统从结构上看,也是可以分为三层的: 物理层:数据实际如何存储 逻辑层:存储的是什么数据,以及数据间是什么关系 试图层:提供给用户的部分数据 关系数据库 目前关于数据库模型最主流的有两种, 一种叫做关系型数据库,这

MySQL数据库学习笔记(十二)----开源工具DbUtils的使用(数据库的增删改查)

[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4085684.html 联系方式:[email protected] [正文] 这一周状态不太好,连续打了几天的点滴,所以博客中断了一个星期,现在继续. 我们在之前的几篇文章中学习了JDBC对数据库的增删改查.其实在实际开发中,一般都是使用第三方工具类,但是只有将之前的基础学习好了,在使用开源工具的

【MySQL】《高性能MySQL》学习笔记,第四章,Schema与数据类型优化

[MySQL]<高性能MySQL>学习笔记,第四章,Schema与数据类型优化 良好的逻辑设计和物理设计是高性能的基石,应该根据系统将要执行的查询语句来设计schema. 反范式的设计可以加快某些类型的查询,单同时可能使另一类型的查询变慢,比如添加计数表和汇总表是一种很好的优化查询的方式,但这些表的维护成本可能会很高. 1.选择优化的数据类型 更小的通常更好. ? 应该尽量使用可以正确存储数据的最小类型,更小的数据类型通常更快,因为他们占用更少的磁盘,内存和CPU缓存,并且处理时需要的CPU周

《Spring3.X企业应用开发实战》学习笔记--DAO和事务

本篇是"<Spring3.X企业应用开发实战>,陈雄华 林开雄著,电子工业出版社,2012.2出版"的学习笔记的第二篇,关于DAO和事务. 本篇从DAO操作,以及事务处理的基本知识谈起,介绍事务本身,以及Spring如何通过注解实现事务. DAO 近几年持久化技术领域异常喧嚣,各种框架如雨后春笋般地冒出,Sun也连接不断的颁布了几个持久化规范. Spring对多个持久化技术提供了持久化支持,包括Hibernate,iBatis,JDO,JPA,TopLink,另外,还通过S

APUE 学习笔记(九) 高级I/O

1. 非阻塞I/O 低速系统调用时可能会使进程永远阻塞的一类系统调用,包括以下调用: (1)某些文件类型你(网络socket套接字.终端设备.管道)暂无可使用数据,则读操作可能会使调用者永远阻塞 (2)如果数据不能立即被(1)中文件类型接受,则写操作会使调用者永远阻塞 (3)某些进程间通信函数 非阻塞I/O使我们可以调用open.read.write这样的I/O操作,并使这些操作不会永远阻塞,如果这种操作不能完成,则调用立即出错返回 对于一个给定的文件有两种方法对其指定非阻塞I/O: (1)调用

python学习笔记九——文件与目录

1.python进行文件读写的函数是open或file类 mode:r  只读 r+   读写 w  写入,先删除原文件,再重新写入,如果文件没有则创建 w+  读写,先删除原文件,再重新写入,如果文件没有则创建(可写入和输出) a  写入,在文件末尾追加新的内容,文件不存在则创建 a+  读写,在文件末尾追加新的内容,文件不存在则创建 b  打开二进制文件,可与r,w,a,+结合使用 U  支持所有的换行符号,"\r","\n","\r\n"