本篇讲述数据库中很是重要的事务概念和如何使用MySQL命令行窗口来进行数据库的事务操做。下一篇会讲述如何使用JDBC进行数据库的事务操做。程序员
事务是指数据库中的一组逻辑操做,这个操做的特色就是在该组逻辑中,全部的操做要么所有成功,要么所有失败。在各个数据具备特别紧密的联系时,最好是使用数据库的事务来完成逻辑处理。sql
例如路人甲A给路人甲B转帐1000元,对应于以下两条SQL命令:数据库
update from account set money=money-1000 where name=’A’; update from account set money=money+1000 where name=’B’;
在上面两条SQL语句中,任意一条SQL执行过程当中出现了错误,那么就有可能形成A与B两人最后总金额的错误。但若是是使用事务来处理,即便上面的转帐过程出现了错误,那么以前执行的数据库操做即便成功也会一并回滚,造成全部的SQL操做所有失败,保证全部人的金额不变。spa
MySQL数据库默认事务是自动提交的,也就是发一条SQL数据库就执行一条。若是想将多条SQL放置在一个事务中执行,就必须使用以下语句:命令行
start transaction sql1 sql2 … commit
当开启事务后(start transaction),不管数据库是否对其中的多条SQL语句是否执行成功,只要没有提交事务(commit),都会将以前执行的SQL进行回滚。使数据回到开启事务以前的值。3d
在MySQL中,与事务相关的有开启事务(START TRANSACTION),提交事务(COMMIT),回滚事务(ROLLBACK)等等,下面将依次使用到。code
接下来将会在先使用数据库命令行窗口来进行事务操做的案例。blog
首先定义表account和客户以及金额两个列数据项:事务
create database jdbcdemo; use jdbcdemo; create table account( id int primary key auto_increment, name varchar(40), money double ); insert into account(name,money) values('a',1000); insert into account(name,money) values('b',1000);
准备完成:rem
输入如下SQL语句,来模拟A向B转帐1000元:
start transaction; update account set money=money-1000 where name=’a’;
假设数据库执行到此发生了错误,咱们将MySQL的命令行窗口关闭来代替这样的“错误”:
这时若是咱们再从新打开MySQL命令行窗口,从新查看用户的金额,发现因为咱们开启事务后,并未提交(commit),所以致使事务回滚,以前执行的SQL语句所有不算成功,所以即便数据库可能发生了错误,用户金额仍是能由事务保证不出意外:
仍是上面的例子,此次咱们在开启事务,输入SQL命令,最后提交事务(Commit),来确保这个事务内全部的SQL命令都能被执行成功,输入如下SQL语句:
start transaction; update account set money=money-1000 where name=’a’; update account set money=money+1000 where name=’b’; commit;
即为下面的样子:
这时候即便我将MySQL命令行窗口关闭模拟提交事务后再出错的状况,那么从新查询用户金额仍是能看出转帐已经在出错前确保完成了:
经过上面两个例子能够看出,若是咱们想将多条SQL做为总体执行,只要有一个条SQL执行失败或者数据库忽然出错就回滚到最开始执行以前的状态,使用事务是最好的选择。
最后来看看事务回滚(ROLLBACK)。若是咱们在事务处理的过程当中,提交事务(Commit)以前,若是想回滚以前的操做,可使用ROLLBACK这条SQL命令。
注:使用ROLLBACK命令将回滚以前到开启事务的全部SQL语句。
仍是以上面的A与B两个用户的金额为例,如今二者的金额都为1000:
如今咱们开启事务,执行几条SQL命令,而后再将这些已经执行的SQL命令回滚:
使用ROLLBACK命令会回滚该事务内全部以前执行的SQL命令,不会只回滚前面一条SQL命令,所以即便咱们对A和B的金额操做了屡次,最终仍是回到事务开启前的金额数:
以上介绍完在数据库命令行窗口如何进行与事务相关的操做,主要就是开启事务,提交事务和回滚事务这三种,固然做为Java程序员,咱们应该仍是使用JDBC来操做数据库的事务处理,这部份内容将会在下一篇博客中介绍到。