事务:一个或一组SQL语句组成一个执行单元,这个执行单元要不全部执行,要不全部不执行。
事务:事务由单独单元的一个或多个SQL语句组成,在这
个单元中,每个MySQL语句是相互依赖的。而整个单独单
元作为一个不可分割的整体,如果单元中某条SQL语句一
旦执行失败或产生错误,整个单元将会回滚。所有受到影
响的数据将返回到事物开始以前的状态;如果单元中的所
有SQL语句均执行成功,则事物被顺利执行。

查看MySQL支持的存储引擎

mysql> show engines;
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| Engine             | Support | Comment                                                        | Transactions | XA   | Savepoints |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| InnoDB             | DEFAULT | Supports transactions, row-level locking, and foreign keys     | YES          | YES  | YES        |
| MRG_MYISAM         | YES     | Collection of identical MyISAM tables                          | NO           | NO   | NO         |
| MEMORY             | YES     | Hash based, stored in memory, useful for temporary tables      | NO           | NO   | NO         |
| BLACKHOLE          | YES     | /dev/null storage engine (anything you write to it disappears) | NO           | NO   | NO         |
| MyISAM             | YES     | MyISAM storage engine                                          | NO           | NO   | NO         |
| CSV                | YES     | CSV storage engine                                             | NO           | NO   | NO         |
| ARCHIVE            | YES     | Archive storage engine                                         | NO           | NO   | NO         |
| PERFORMANCE_SCHEMA | YES     | Performance Schema                                             | NO           | NO   | NO         |
| FEDERATED          | NO      | Federated MySQL storage engine                                 | NULL         | NULL | NULL       |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
9 rows in set (0.00 sec)
其中InnoDB支持事务,而myisam、memory不支持事务

事务的ACID(acid)属性
1、原子性(Atomicity)

原子性是指事务是一个不可分割的工作单位,事务中的操作要么
都发生,要么都不发生。

2、一致性(Consistency)

事务必须使数据库从一个一致性状态变换到另外一个一致性状态

3、隔离性(Isolation)

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

4、持久性(Durability)

持久性是指一个事务一旦被提交,它对数据库中数据的改变就是
永久性的,接下来的其他操作和数据库故障不应该对其有任何影

事务的创建
隐式事务:事务没有明显的开启和结束的标记
如insert、update、delete
显式事务:事务具有明显的开启和结束标记
前提:必须先设置自动提交功能为禁用

mysql> set autocommit=0;
Query OK, 0 rows affected (0.00 sec)

mysql> show variables like'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit    | OFF   |
+---------------+-------+
1 row in set, 1 warning (0.00 sec)

创建事务

步骤1:开启事务
set autocommit=0;
start transaction;可选的
步骤2:编写事务中的sql语句(select insert update delete)
语句1;
语句2;
...

步骤3:结束事务
commit;提交事务
rollback;回滚事务

savepoint 节点名;设置保存点

查看事务隔离级别

mysql> select @@tx_isolation;
+-----------------+
| @@tx_isolation  |
+-----------------+
| REPEATABLE-READ |
+-----------------+
1 row in set, 1 warning (0.00 sec)

设置隔离级别

mysql> set session transaction isolation level read uncommitted;
Query OK, 0 rows affected (0.00 sec)

mysql> select @@tx_isolation;
+------------------+
| @@tx_isolation   |
+------------------+
| READ-UNCOMMITTED |
+------------------+
1 row in set, 1 warning (0.00 sec)

更多MySQL命令