MySQL中的事务

来源:互联网 发布:网站备案 知乎 编辑:程序博客网 时间:2024/06/06 12:03

1 事务介绍
  本篇文章我们来介绍数据库中事务的概念以及如何使用MySQL命令行窗口来进行数据库的事务操作。事务是联合操作中我们数据库稳定运作和数据不发生不可预知错误的重要依赖。
  事务是指数据库中的一组逻辑操作,这个操作的特点就是在该组逻辑中,所有的操作要么全部成功,要么全部失败。在各个数据具有特别紧密的联系时,最好是使用数据库的事务来完成逻辑处理。
2 实例介绍
  我们先假设有一组数据操作是银行转账,A用户给B用户转账10000元,则MySQL有以下的操作:

update account set count = count - 10000 where name = 'A';update account set count = count + 10000 where name = 'B';

  在上面两条SQL语句中,任意一条SQL执行过程中出现了错误,或者第一条正常执行,第二条由于网络中断请求失败,那么就有可能造成A与B两人最后总金额的错误。但如果是使用事务来处理,即使上面的转账过程出现了错误,那么之前执行的数据库操作即使成功也会一并回滚,形成所有的SQL操作全部失败,保证所有人的金额不变。
  MySQL数据库默认事务是自动提交的,也就是发一条SQL数据库就执行一条。如果想将多条SQL放置在一个事务中执行,就必须使用如下语句:

    start  transaction    sql1    sql2    …    commit

  当开启事务后(start transaction),无论数据库是否对其中的多条SQL语句是否执行成功,只要没有提交事务(commit),都会将之前执行的SQL进行回滚。使数据回到开启事务之前的值。
  在MySQL中,与事务相关的有开启事务(START TRANSACTION),提交事务(COMMIT),回滚事务(ROLLBACK)等等,下面将依次使用到。
  接下来将会在先使用数据库命令行窗口来进行事务操作的案例。
 2.1 定义数据库与表
  首先定义表account和客户以及金额两个列数据项:

    create database bank;    use bank;    create table account(         id int primary key auto_increment,         name varchar(40),         money double    );    insert into account(name,money) values('a',50000);    insert into account(name,money) values('b',80000);

 2.2 开启事务模拟转账
  接下来我们再开启事务模拟转账,输入SQL命令,最后提交事务(Commit),来确保这个事务内所有的SQL命令都能被执行成功,依次输入以下SQL语句:

    start transaction; -- 开启事务    update account set money=money-10000 where name=’A’;    update account set money=money+10000 where name=’B’;    commit;  -- 提交事务

  上面提交才能真正意义上将所有事务中逻辑命令执行,所以说如果我们想将多条SQL作为整体执行,只要有一个条SQL执行失败或者数据库突然出错就回滚到最开始执行之前的状态,使用事务是最好的选择。
 2.3 回滚事务
  最后来看看事务回滚(ROLLBACK)。如果我们在事务处理的过程中,提交事务(Commit)之前,如果想回滚之前的操作,可以使用ROLLBACK这条SQL命令。

rollback;

  注:使用ROLLBACK命令将回滚之前到开启事务的所有SQL语句,而不会只回滚前面一条SQL命令,因此即使我们对A和B的金额操作了多次,最终还是回到事务开启前的金额数。
  
  以上就是本文主要想介绍的开启事务,提交事务和回滚事务三种关于事务的操作。


  参考博客:
  http://www.cnblogs.com/fjdingsd/p/5272952.html

原创粉丝点击