欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL transaction事務(wù)安全示例講解

 更新時(shí)間:2022年06月18日 09:24:14   作者:彭世瑜  
這篇文章主要為大家介紹了MySQL數(shù)據(jù)庫事務(wù)安全transaction的示例講解教程,事務(wù)就是將一組操作封裝成一個(gè)執(zhí)行單元,要么一塊執(zhí)行成功,要么一塊失敗,不存在部分執(zhí)行成功的情況。事務(wù)保證了執(zhí)行的穩(wěn)定性,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步

事務(wù)安全 transaction

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

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

事務(wù)基本原理

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

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

自動(dòng)事務(wù)

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

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

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

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

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

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

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

  • commit 提交 (同步到數(shù)據(jù)表,事務(wù)會(huì)被清空)
  • rollback 回滾 (清空之前的操作,不要了)
-- 客戶端A關(guān)閉自動(dòng)事務(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)閉自動(dòng)事務(wù),需要使用事務(wù)的時(shí)候,使用手動(dòng)事務(wù)

手動(dòng)事務(wù)

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

手動(dòng)事務(wù)指令

-- 1、開啟事務(wù),從這條語句開始,后面所有的語句都不會(huì)直接寫入到數(shù)據(jù)表,保存在事務(wù)日志中
start transaction 
-- 2、事務(wù)處理,多個(gè)指令構(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ù)操作,多個(gè)修改操作
insert into my_class (name)values ('六班');
insert into my_student (name, class_id, age, gender)values ('司馬懿', 6, 26, 1);
-- 提交事務(wù)
commit;
-- 或者回滾操作,所有數(shù)據(jù)無效清空
rollback;

回滾點(diǎn)

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

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

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

事務(wù)的特點(diǎn)

ACID:

  • 原子性 automicity 一個(gè)事務(wù)是不可分割的工作單元,要么都做,要么都不做
  • 一致性 consistency 事務(wù)必須是使數(shù)據(jù)庫從一個(gè)一致性狀態(tài)變到另一個(gè)一致性狀態(tài)
  • 隔離性 isolation 一個(gè)事務(wù)的執(zhí)行,不能被其他事務(wù)干擾,操作數(shù)據(jù)的時(shí)候會(huì)鎖住該條數(shù)據(jù)
  • 持久性 durability 一個(gè)事務(wù)一旦提交,他對數(shù)據(jù)庫中的數(shù)據(jù)改變就是永久的

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

到此這篇關(guān)于MySQL transaction事務(wù)安全示例講解 的文章就介紹到這了,更多相關(guān)MySQL transaction 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL中interactive_timeout和wait_timeout的區(qū)別

    MySQL中interactive_timeout和wait_timeout的區(qū)別

    這篇文章主要介紹了MySQL中interactive_timeout和wait_timeout的區(qū)別,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-10-10
  • MySQL Limit性能優(yōu)化及分頁數(shù)據(jù)性能優(yōu)化詳解

    MySQL Limit性能優(yōu)化及分頁數(shù)據(jù)性能優(yōu)化詳解

    今天小編就為大家分享一篇關(guān)于MySQL Limit性能優(yōu)化及分頁數(shù)據(jù)性能優(yōu)化詳解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • 詳解MySQL 表中非主鍵列溢出情況監(jiān)控

    詳解MySQL 表中非主鍵列溢出情況監(jiān)控

    這篇文章主要介紹了詳解MySQL 表中非主鍵列溢出情況監(jiān)控,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • 一文帶大家由淺入深的了解MySQL底層查詢邏輯

    一文帶大家由淺入深的了解MySQL底層查詢邏輯

    這篇文章主要給大家詳細(xì)介紹了MySQL底層查詢邏輯,文中有詳細(xì)的代碼示例和圖文介紹,具有一定的參考價(jià)值,感興趣的同學(xué)可以借鑒閱讀
    2023-06-06
  • MySQL刪除數(shù)據(jù)庫的兩種方法

    MySQL刪除數(shù)據(jù)庫的兩種方法

    這篇文章主要為大家詳細(xì)介紹了MySQL刪除數(shù)據(jù)庫的兩種方法,感興趣的小伙伴們可以參考一下
    2016-06-06
  • mysql5.7.19 zip 詳細(xì)安裝過程和配置

    mysql5.7.19 zip 詳細(xì)安裝過程和配置

    本文詳細(xì)給大家介紹了mysql5.7.19 zip 詳細(xì)安裝過程和配置,感興趣的朋友一起看看吧
    2017-10-10
  • mysql 添加用戶并分配select權(quán)限的實(shí)現(xiàn)

    mysql 添加用戶并分配select權(quán)限的實(shí)現(xiàn)

    在開發(fā)MySQL應(yīng)用程序時(shí),為了保證數(shù)據(jù)的安全性和準(zhǔn)確性,通常需要設(shè)置不同級別的用戶權(quán)限,本文主要介紹了mysql 添加用戶并分配select權(quán)限的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • MySQL正確修改最大連接數(shù)的3種方案

    MySQL正確修改最大連接數(shù)的3種方案

    這篇文章主要給大家介紹了關(guān)于MySQL正確修改最大連接數(shù)的3種方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • mysql慢查詢優(yōu)化之從理論和實(shí)踐說明limit的優(yōu)點(diǎn)

    mysql慢查詢優(yōu)化之從理論和實(shí)踐說明limit的優(yōu)點(diǎn)

    今天小編就為大家分享一篇關(guān)于mysql慢查詢優(yōu)化之從理論和實(shí)踐說明limit的優(yōu)點(diǎn),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-04-04
  • Mysql binlog日志文件過大的解決

    Mysql binlog日志文件過大的解決

    本文主要介紹了Mysql binlog日志文件過大的解決,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09

最新評論