一.场景导入

现在有一张仓库表,仓库表中记录了每一个物品的数量,还有一张用户表,用户购买产品,仓库表的产品数量减少,而用户拥有产品的数量增加。

但是如果仓库中的产品数量不足时怎么处理?

例子:

#仓库表
create table if not exists Warehouse(
pro_id int primary key,
pro_name varchar(10),
pro_num int not null
); #用户表,用户表中的co_pro与仓库表中pro_id为外键关系
create table customer(
co_name varchar(10),
co_pro int ,
co_pro_num int default -1,
foreign key (co_pro) references warehouse(pro_id)
);

仓库表:用户表:

创建一个购买的存储过程后:

#购买商品存储过程
delimiter //
create procedure buy(in buy_num int)
begin
#首先将仓库表中的数量减去
update warehouse set pro_num=pro_num-buy_num where pro_id = 100001;
#增加用户手里的商品数目
update customer set co_pro_num=co_pro_num+buy_num where co_pro=100001;
end
//

在表面上似乎没有问题,但是没有考虑到情况当我仓库中数目不足是怎么办?

例子:

call buy(11);

在这里巧克力数目出现了负数,那么这就是一个最基本的逻辑错误,想要避免这样的错误就可以使用事务的回滚。

二.什么是事务?

事务其实和存储过程、存储函数一样也是一个sql语句的聚合体。

在这个聚合体中也是执行某个操作,但是这个操作将是一个整体,如果单元中某一条语句执行失败了或者产生了错误,那么将会将整个单元回滚,此前的执行操作将全部取消,数据库将返回执行事务前的状态。

四.事务的四个特征

1.原子性

原子性理解就是:事务中的sql语句全部执行或者全部不执行。上面的例子中如果购买11个商品是不正确的那么用户也不会增加11个商品即增加的sql语句也不会执行即全部不执行,如果购买10个正确那么就可以执行增加数量的sql语句即全部执行。

2.一致性

一致性理解就是:无论这个事物是否成功还是失败,事务会使得数据库处于一致状态下,保持逻辑和数据的一致性。

比如说用户购买10个巧克力成功时那么用户的数据库中增加10个商品,而仓库中的数量减少10个,失败时回滚,回到购买前的数据状态。这样无论是在数据库在成功还是失败状态下,逻辑和数据都是一致性的。

3.隔离性

多个事务在执行时他们是不能相互干扰的。

4.永久性

如果一个事务提交,那么这个事务所造成的影响就就是永久的不可以在回滚的。

三.创建事务

3.1 MySQL中支持事务表的类型

在MySQL中支持事务表的类型有innoDBBDB两种。所以在创建表时要选择表的类型。

3.2 创建一个事务

语法:start transaction;      #初始化事务

   事务主体

     commit  | rollback   #提交事务或者回滚

下面我们将上一个存储过程加上一个事务:

#购买商品存储过程,使用事务
delimiter //
create procedure buy(in buy_num int)
begin
declare pro_ture_num int default -1;#局部变量获得减去后的数量
#首先将仓库表中的数量减去
start transaction;#开启事务
update warehouse set pro_num=pro_num-buy_num where pro_id = 100001;
set pro_ture_num=(select pro_num from warehouse where pro_id = 100001);
if pro_ture_num >=0 then
#增加用户手里的商品数目
update customer set co_pro_num=co_pro_num+buy_num where co_pro=100001;
else
rollback;
end if;
end
//

来调用一下这个有事务的存储过程:

测试1:

call buy(11);

结果:

测试2:

call buy(9);

结果

举例说明MySQL中的事务的更多相关文章

  1. 【MySQL】漫谈MySQL中的事务及其实现

    最近一直在做订单类的项目,使用了事务.我们的数据库选用的是MySQL,存储引擎选用innoDB,innoDB对事务有着良好的支持.这篇文章我们一起来扒一扒事务相关的知识. 为什么要有事务? 事务广泛的 ...

  2. 漫谈MySql中的事务

    最近一直在做订单类的项目,使用了事务.我们的数据库选用的是MySql,存储引擎选用innoDB,innoDB对事务有着良好的支持.这篇文章我们一起来扒一扒事务相关的知识. 为什么要有事务? 事务广泛的 ...

  3. (转)漫谈MySql中的事务

    最近一直在做订单类的项目,使用了事务.我们的数据库选用的是MySql,存储引擎选用innoDB,innoDB对事务有着良好的支持.这篇文章我们一起来扒一扒事务相关的知识. 为什么要有事务? 事务广泛的 ...

  4. 【转】全面了解Mysql中的事务

    为什么要有事务? 事务广泛的运用于订单系统.银行系统等多种场景.如果有以下一个场景:A用户和B用户是银行的储户.现在A要给B转账500元.那么需要做以下几件事: 1. 检查A的账户余额>500元 ...

  5. MySql中的事务嵌套

    1.Mysql中的事务必须是InnoDB.Berkeley DB引擎,myisam不支持. 2.Mysql是不支持嵌套事务的,开启了一个事务的情况下,再开启一个事务,会隐式的提交上一个事务. 3.My ...

  6. MySQL中Procedure事务编写基础笔记

    原文:MySQL中Procedure事务编写基础笔记 目录: 一.PROCEDURE: 二.CREATE PROCEDURE基本语法: 三.PROCEDURE小进阶   3.1.基本的DECLARE语 ...

  7. MySql中的事务、JDBC事务、事务隔离级别

    一.MySql事务 之前在Oracle中已经学习过事务了,这个东西就是这个东西,但是在MySql中用法还是有一点不同,正好再次回顾一下. 先看看MySql中的事务,默认情况下,每执行一条SQL语句,都 ...

  8. 在MySQL中设置事务隔离级别有2种方法:

    在MySQL中设置事务隔离级别有2种方法: 1 在my.cnf中设置,在mysqld选项中如下设置 [mysqld] transaction-isolation = READ-COMMITTED 2 ...

  9. 十:MYSQL中的事务

    前言: 因为没有多少时间和精力,目前无法深入研究数据库中的事务,比如 但是,对于事务的一些基本知识,还是需要牢牢掌握的,做到了解事务的基本常识,在实际开发中能够理解各个持久层框架对事务的处理 一:是么 ...

随机推荐

  1. Linux安装配置samba教程(CentOS 6.5)

    一.服务端安装配置samba 1.1 服务端安装samba yum install -y samba 1.2 创建共享目录并写入配置文件 以/samba为共享目录为例,为了更直观地观测我们在该目录中创 ...

  2. Nginx反向代理配置教程(php-fpm)

    1.安装nginx http://www.cnblogs.com/lsdb/p/6543441.html 2.安装php-fpm yum install -y php-fpm 3.配置Nginx反向代 ...

  3. 记录一次面试中的HTTP请求相关问题

    1.HTTP中的状态码分别代表什么 比较基础,自行百度.   2.HTTP请求,响应头部content-length用来做什么的 答:Content-Length首部告诉浏览器报文中实体主体的大小.这 ...

  4. LY.JAVA面向对象编程.修饰符

    2018-07-18 09:20:25 /* 修饰符: 权限修饰符:private,默认的,protected,public 状态修饰符:static,final 抽象修饰符:abstract 类: ...

  5. java的八大排序

    public class Sort2 { public static void main(String[] args) { Sort2 sort = new Sort2(); System.out.p ...

  6. java④

    1. 一元运算符:一个表达式就可以参与运算! * ++ -- * * 二元运算符:二个表达式就可以参与运算! * + / * - % * * 三元运算符:三个表达式就可以参与运算! * 数据类型 变量 ...

  7. 【转】用深度学习做crowd density estimation

    本博文主要是CVPR2016的<Single-Image Crowd Counting via Multi-Column Convolutional Neural Network>这篇文章 ...

  8. c# async/await异步编程死锁的问题

    在异步编程中,如果稍有不注意,就会造成死锁问题.何为死锁:即两个以上的线程同时争夺被互相锁住的资源,两个都不放手. 在UI或asp.net中,容易造成死锁的代码如下所示: private void b ...

  9. 根据题目完成以下50道SQL语句

    已知有如下4张表: 学生表:STUDENT(S#,SNAME,SAGE,SSEX) 课程表:COURSE(C#,CNAME,T#) 成绩表:SC(S#,C#,SCORE) 教师表:TEACHER(T# ...

  10. java中的方法method

    java中的方法必须存在于类class里,不能独立存在.类是描述具有某种特征的事物,方法则是这类 事物具有的某种功能,通过调用方法可以实现某种特定的功能.方法名一般以小写的动词开头. 例: publi ...