Mysql中的事务是啥如何使用
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql中的事务是啥如何使用相关的知识,希望对你有一定的参考价值。
什么是事务?事务是逻辑上的一组操作,组成这组操作的各个单元,要不全都成功要不全都失败,这个特性就是事务
注意:mysql数据支持事务,但是要求必须是innoDB存储引擎
解决这个问题:
mysql的事务解决这个问题,因为mysql的事务特性,要求这组操作,要不全都成功,要不全都失败,这样就避免了某个操作成功某个操作失败。利于数据的安全
如何使用:
(1)在执行sql语句之前,我们要开启事务 start transaction;
(2)正常执行我们的sql语句
(3)当sql语句执行完毕,存在两种情况:
1,全都成功,我们要将sql语句对数据库造成的影响提交到数据库中,committ
2,某些sql语句失败,我们执行rollback(回滚),将对数据库操作赶紧撤销
(注意:mysql数据支持事务,但是要求必须是innoDB存储引擎)
mysql> create table bank(name varchar(20),money decimal(5,1))engine=innodb defau
lt charset=utf8;
mysql> inset into bank values('shaotuo',1000),('laohu',5000);
mysql> select*from bank;
+---------+--------+
| name | money |
+---------+--------+
| shaotuo | 1000.0 |
| laohu | 5000.0 |
+---------+--------+
------没有成功“回滚”执行rollback
mysql> start transaction; //开启事务
Query OK, 0 rows affected (0.00 sec)
mysql> update bank set money=money+500 where name='shaotuo';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> update bank set moey=money-500 where name='laohu';
ERROR 1054 (42S22): Unknown column 'moey' in 'field list'
mysql> rollback; //只要有一个不成功,执行rollback操作
Query OK, 0 rows affected (0.01 sec)
mysql> select*from bank;
+---------+--------+
| name | money |
+---------+--------+
| shaotuo | 1000.0 |
| laohu | 5000.0 |
+---------+--------+
------成功之后 进行commit操作
mysql> start transaction; //开启事务
Query OK, 0 rows affected (0.00 sec)
mysql> update bank set money=money+500 where name='shaotuo';
Query OK, 1 row affected (0.01 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> update bank set money=money-500 where name='laohu';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> commit; //两个都成功后执行commit(只要不执行commit,sql语句不会对真实的数据库造成影响)
Query OK, 0 rows affected (0.05 sec)
mysql> select*from bank;
+---------+--------+
| name | money |
+---------+--------+
| shaotuo | 1500.0 |
| laohu | 4500.0 |
+---------+--------+ 参考技术A 1. 普通事务
以 begin / start transaction 开始,commit / rollback 结束的事务。或者是带有保存点 savepoint 的事务。
2. 链式事务
一个事务在提交的时候自动将上下文传给下一个事务,也就是说一个事务的提交和下一个事务的开始是原子性的,下一个事务可以看到上一个事务的处理结果。MySQL 的链式事务靠参数 completion_type 控制,并且回滚和提交的语句后面加上 work 关键词。
3. 嵌套事务
有多个 begin / commit / rollback 这样的事务块的事务,并且有父子关系。子事务的提交完成后不会真的提交,而是等到父事务提交才真正的提交。
4. 自治事务
内部事务的提交不随外部事务的影响,一般用作记录内部事务的异常情况。MySQL 不支持自治事务,但是某些场景可以用 MySQL 的插件式引擎来变相实现。
MySql学习18----数据库事务---命令使用(02)
本篇讲述数据库中非常重要的事务概念和如何使用MySQL命令行窗口来进行数据库的事务操作。下一篇会讲述如何使用JDBC进行数据库的事务操作。
事务是指数据库中的一组逻辑操作,这个操作的特点就是在该组逻辑中,所有的操作要么全部成功,要么全部失败。在各个数据具有特别紧密的联系时,最好是使用数据库的事务来完成逻辑处理。
例如路人甲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操作全部失败,保证所有人的金额不变。
MySQL数据库默认事务是自动提交的,也就是发一条SQL数据库就执行一条。如果想将多条SQL放置在一个事务中执行,就必须使用如下语句:
start transaction sql1 sql2 … commit
当开启事务后(start transaction),无论数据库是否对其中的多条SQL语句是否执行成功,只要没有提交事务(commit),都会将之前执行的SQL进行回滚。使数据回到开启事务之前的值。
在MySQL中,与事务相关的有开启事务(START TRANSACTION),提交事务(COMMIT),回滚事务(ROLLBACK)等等,下面将依次使用到。
接下来将会在先使用数据库命令行窗口来进行事务操作的案例。
首先定义表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);
准备完成:
⑴ 开启事务,先来模拟转账“失败”的情况:
输入以下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执行失败或者数据库突然出错就回滚到最开始执行之前的状态,使用事务是最好的选择。
⑶ 回滚事务,将之前所有已执行的SQL全部视为无效:
最后来看看事务回滚(ROLLBACK)。如果我们在事务处理的过程中,提交事务(Commit)之前,如果想回滚之前的操作,可以使用ROLLBACK这条SQL命令。
注:使用ROLLBACK命令将回滚之前到开启事务的所有SQL语句。
还是以上面的A与B两个用户的金额为例,现在两者的金额都为1000:
现在我们开启事务,执行几条SQL命令,然后再将这些已经执行的SQL命令回滚:
使用ROLLBACK命令会回滚该事务内所有之前执行的SQL命令,不会只回滚前面一条SQL命令,因此即使我们对A和B的金额操作了多次,最终还是回到事务开启前的金额数:
以上介绍完在数据库命令行窗口如何进行与事务相关的操作,主要就是开启事务,提交事务和回滚事务这三种,当然作为Java程序员,我们应该还是使用JDBC来操作数据库的事务处理,这部分内容将会在下一篇博客中介绍到。
MyNote: 学习数据库可以结合JDBC一起来操作。调用JAVA的API来实现数据库操作。
转自:https://www.cnblogs.com/fjdingsd/p/5272952.html
以上是关于Mysql中的事务是啥如何使用的主要内容,如果未能解决你的问题,请参考以下文章
事务和锁机制是啥关系? 开启事务就自动加锁了吗? 菜鸟,谢谢了。
## 分布式事务面试官问我:MySQL中的XA事务崩溃了如何恢复??