您好,登錄后才能下訂單哦!
這篇文章主要介紹“MySQL transaction事務(wù)安全怎么實現(xiàn)”,在日常操作中,相信很多人在MySQL transaction事務(wù)安全怎么實現(xiàn)問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”MySQL transaction事務(wù)安全怎么實現(xiàn)”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
事務(wù) transaction 訪問可能更新數(shù)據(jù)庫中各種數(shù)據(jù)項的一個程序執(zhí)行單元unit
事務(wù)由事務(wù)開始(begin transaction)和事務(wù)結(jié)束(end transaction)之間執(zhí)行的全體操作組成
MySQL允許將事務(wù)統(tǒng)一進行管理(存儲引擎innodb),將用戶所做的操作,暫時保存起來,不直接放到數(shù)據(jù)表(更新),等到用戶確認結(jié)果之后再進行操作
事務(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ù)
開始、過程、結(jié)束,都要用戶手動發(fā)送事務(wù)操作指令來實現(xiàn)
手動事務(wù)指令
-- 1、開啟事務(wù),從這條語句開始,后面所有的語句都不會直接寫入到數(shù)據(jù)表,保存在事務(wù)日志中 start transaction -- 2、事務(wù)處理,多個指令構(gòu)成 -- 3、事務(wù)提交,結(jié)束事務(wù) commit / rollback
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è)置多個回滾點
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>
免責(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)容。