程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> Mysql中的事務是甚麼若何應用

Mysql中的事務是甚麼若何應用

編輯:MySQL綜合教程

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 |
+---------+--------+
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved