Mysql中的事務是甚麼若何應用。本站提示廣大學習愛好者:(Mysql中的事務是甚麼若何應用)文章只能為提供參考,不一定能成為您想要的結果。以下是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 |
+---------+--------+