事務(wù)操作

2018-06-20 10:41 更新
一、為什么使用事務(wù)

      MySQL 事務(wù)主要用于處理操作量大,復雜度高的數(shù)據(jù)。比如說,在人員管理系統(tǒng)中,你刪除一個人員,你即需要刪除人員的基本資料,也要刪除和該人員相關(guān)的信息,如信箱,文章等等,這樣,這些數(shù)據(jù)庫操作語句就構(gòu)成一個事務(wù)!

二、什么情況下使用事務(wù)

   1、 在 MySQL 中只有使用了 Innodb 數(shù)據(jù)庫引擎的數(shù)據(jù)庫或表才支持事務(wù)。

   2、事務(wù)處理可以用來維護數(shù)據(jù)庫的完整性,保證成批的 SQL 語句要么全部執(zhí)行,要么全部不執(zhí)行。

   3、事務(wù)用來管理 insert,update,delete 語句

三、使用事務(wù)的條件

    Atomicity(原子性)、Consistency(穩(wěn)定性)、Isolation(隔離性)、Durability(可靠性)

    1、事務(wù)的原子性:一組事務(wù),要么成功;要么撤回。

    2、穩(wěn)定性 :有非法數(shù)據(jù)(外鍵約束之類),事務(wù)撤回。

    3、隔離性:事務(wù)獨立運行。一個事務(wù)處理后的結(jié)果,影響了其他事務(wù),那么其他事務(wù)會撤回。事務(wù)的100%隔離,需要犧牲速度。

    4、可靠性:軟、硬件崩潰后,InnoDB數(shù)據(jù)表驅(qū)動會利用日志文件重構(gòu)修改。可靠性和高速度不可兼得  innodb_flush_log_at_trx_commit 選項 決定什么時候吧事務(wù)保存到日志里。

    在 MySQL 命令行的默認設(shè)置下,事務(wù)都是自動提交的,即執(zhí)行 SQL 語句后就會馬上執(zhí)行 COMMIT 操作。因此要顯示地開啟一個事務(wù)須使用命令 BEGIN 或 START TRANSACTION,或者執(zhí)行命令 SET AUTOCOMMIT=0,用來禁止使用當前會話的自動提交。

四、事物控制語句

    1、BEGIN或START TRANSACTION;顯示地開啟一個事務(wù);

    2、COMMIT;也可以使用COMMIT WORK,不過二者是等價的。COMMIT會提交事務(wù),并使已對數(shù)據(jù)庫進行的所有修改稱為永久性的;

    3、ROLLBACK;有可以使用ROLLBACK WORK,不過二者是等價的?;貪L會結(jié)束用戶的事務(wù),并撤銷正在進行的所有未提交的修改;

    4、SAVEPOINT identifier;SAVEPOINT允許在事務(wù)中創(chuàng)建一個保存點,一個事務(wù)中可以有多個SAVEPOINT;

    5、RELEASE SAVEPOINT identifier;刪除一個事務(wù)的保存點,當沒有指定的保存點時,執(zhí)行該語句會拋出一個異常;

    6、ROLLBACK TO identifier;把事務(wù)回滾到標記點;

    7、SET TRANSACTION;用來設(shè)置事務(wù)的隔離級別。InnoDB存儲引擎提供事務(wù)的隔離級別有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ和SERIALIZABLE。

五、實現(xiàn)方法

     1、用 BEGIN, ROLLBACK, COMMIT來實現(xiàn)

         BEGIN 開始一個事務(wù)

         ROLLBACK 事務(wù)回滾

         COMMIT 事務(wù)確認

     2、直接用 SET 來改變 MySQL 的自動提交模式:

        SET AUTOCOMMIT=0 禁止自動提交

        SET AUTOCOMMIT=1 開啟自動提交

       




以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號