溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

MySQL?transaction事務(wù)安全怎么實現(xiàn)

發(fā)布時間:2022-06-18 13:55:24 來源:億速云 閱讀:107 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“MySQL transaction事務(wù)安全怎么實現(xiàn)”,在日常操作中,相信很多人在MySQL transaction事務(wù)安全怎么實現(xiàn)問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”MySQL transaction事務(wù)安全怎么實現(xiàn)”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

事務(wù)安全 transaction

事務(wù) transaction 訪問可能更新數(shù)據(jù)庫中各種數(shù)據(jù)項的一個程序執(zhí)行單元unit

事務(wù)由事務(wù)開始(begin transaction)和事務(wù)結(jié)束(end transaction)之間執(zhí)行的全體操作組成

事務(wù)基本原理

MySQL允許將事務(wù)統(tǒng)一進行管理(存儲引擎innodb),將用戶所做的操作,暫時保存起來,不直接放到數(shù)據(jù)表(更新),等到用戶確認結(jié)果之后再進行操作

事務(wù)通常是自動提交,也可以手動提交

自動事務(wù)

當客戶端發(fā)送一條SQL指令(寫操作,增刪改)給服務(wù)器的時候,服務(wù)器在執(zhí)行后,不用等待用戶反饋結(jié)果,會自動將結(jié)果同步到數(shù)據(jù)表

兩個客戶端,一個客戶端執(zhí)行SQL指令,另一個客戶端查看執(zhí)行結(jié)果

通過變量控制自動事務(wù)

mysql> show variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit    | ON    |
+---------------+-------+
-- 關(guān)閉自動事務(wù)
set autocommit = off;

mysql> show variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit    | OFF   |
+---------------+-------+

關(guān)閉自動事務(wù)之后,一個客戶端修改數(shù)據(jù),另個一客戶端看不到修改的結(jié)果

一旦關(guān)閉自動事務(wù),就需要用戶提供是否同步的命令

  • commit 提交 (同步到數(shù)據(jù)表,事務(wù)會被清空)

  • rollback 回滾 (清空之前的操作,不要了)

-- 客戶端A關(guān)閉自動事務(wù)后操作數(shù)據(jù)
mysql> select * from my_class;
+----+--------+
| id | name   |
+----+--------+
|  1 | 一班   |
|  3 | 三班   |
+----+--------+
2 rows in set (0.01 sec)
mysql> insert into my_class (name) values('四班');
Query OK, 1 row affected (0.00 sec)

mysql> select * from my_class;
+----+--------+
| id | name   |
+----+--------+
|  1 | 一班   |
|  3 | 三班   |
|  5 | 四班   |
+----+--------+
3 rows in set (0.00 sec)
-- 客戶端B看不到新增的 四班數(shù)據(jù), 
mysql> select * from my_class;
+----+--------+
| id | name   |
+----+--------+
|  1 | 一班   |
|  3 | 三班   |
+----+--------+
2 rows in set (0.00 sec)

客戶端A執(zhí)行commit 提交事務(wù)之后,客戶端B就可以看到新增的數(shù)據(jù)了

通常不需要關(guān)閉自動事務(wù),需要使用事務(wù)的時候,使用手動事務(wù)

手動事務(wù)

開始、過程、結(jié)束,都要用戶手動發(fā)送事務(wù)操作指令來實現(xiàn)

手動事務(wù)指令

-- 1、開啟事務(wù),從這條語句開始,后面所有的語句都不會直接寫入到數(shù)據(jù)表,保存在事務(wù)日志中
start transaction 
-- 2、事務(wù)處理,多個指令構(gòu)成
-- 3、事務(wù)提交,結(jié)束事務(wù)
commit / rollback

事務(wù)的使用

mysql> select * from my_class;
+----+--------+
| id | name   |
+----+--------+
|  1 | 一班   |
|  3 | 三班   |
|  5 | 四班   |
+----+--------+
3 rows in set (0.04 sec)
mysql> select * from my_student;
+----+--------+----------+------+--------+
| id | name   | class_id | age  | gender |
+----+--------+----------+------+--------+
|  1 | 劉備   |        1 |   18 |      2 |
|  2 | 李四   |        1 |   19 |      1 |
|  3 | 王五   |     NULL |   20 |      2 |
|  4 | 張飛   |     NULL |   21 |      1 |
|  5 | 關(guān)羽   |     NULL |   22 |      2 |
|  6 | 曹操   |        1 |   20 |   NULL |
+----+--------+----------+------+--------+
6 rows in set (0.00 sec)
-- 開啟事務(wù)
start transaction;
-- 執(zhí)行事務(wù)操作,多個修改操作
insert into my_class (name)values ('六班');
insert into my_student (name, class_id, age, gender)values ('司馬懿', 6, 26, 1);
-- 提交事務(wù)
commit;
-- 或者回滾操作,所有數(shù)據(jù)無效清空
rollback;

回滾點

當有一系列事務(wù)操作是,而其中的步驟如果成功了,沒有必要重新來過,可以在某個點,設(shè)置一個記號(回滾點),然后如果后面有失敗,那么可以回到這個記號的位置

-- 增加回滾點
savepoint 回滾點名字;
-- 回到回滾點 清空之后所有操作
rollback to 回滾點名字;

一個事務(wù)處理過程中,如果有很多步驟,可以設(shè)置多個回滾點

事務(wù)的特點

ACID:

  • 原子性 automicity 一個事務(wù)是不可分割的工作單元,要么都做,要么都不做

  • 一致性 consistency 事務(wù)必須是使數(shù)據(jù)庫從一個一致性狀態(tài)變到另一個一致性狀態(tài)

  • 隔離性 isolation 一個事務(wù)的執(zhí)行,不能被其他事務(wù)干擾,操作數(shù)據(jù)的時候會鎖住該條數(shù)據(jù)

  • 持久性 durability 一個事務(wù)一旦提交,他對數(shù)據(jù)庫中的數(shù)據(jù)改變就是永久的

如果條件中使用了索引,會隔離一條記錄;反之,通過全表檢索,會鎖定整個表

到此,關(guān)于“MySQL transaction事務(wù)安全怎么實現(xiàn)”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI