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

簡單介紹MySQL中的事務機制

 更新時間:2015年04月13日 17:04:51   作者:楊國棟  
這篇文章主要介紹了MySQL中的事務機制,通過實例介紹了大概的流程,需要的朋友可以參考下

從一個問題開始

最近銀行這個事情鬧的比較厲害啊,很多儲戶的錢放在銀行,就不翼而飛了,而銀行還不管不問,說是用戶的責任,打官司,用戶還能輸了,這就是“社會主義”。咱還是少發(fā)牢騷,多種樹,莫談國事。

說到銀行存錢,就不得不說一下從銀行取錢這件事情,從ATM機取錢這件簡單的事情,實際上主要分為以下幾個步驟:

  1.     登陸ATM機,輸入密碼;
  2.     連接數(shù)據(jù)庫,驗證密碼;
  3.     驗證成功,獲得用戶信息,比如存款余額等;
  4.     用戶輸入需要取款的金額,按下確認鍵;
  5.     從后臺數(shù)據(jù)庫中減掉用戶賬戶上的對應金額;
  6.     ATM吐出錢;
  7.     用戶把錢拿走。

一個簡單的取錢,主要分為以上幾步。不知道大家有沒有“天真”的想過,如果在第5步中,后臺數(shù)據(jù)庫中已經(jīng)把錢減掉了,但是ATM還就是沒有吐出錢(雖然實際也發(fā)生過,但是畢竟是低概率事件),這該怎么辦?

關于這個問題,銀行系統(tǒng)的開發(fā)人員早就想過了,那么他們是怎么來搞定這個問題的呢?這就要說到今天總結的事務這個概念了。
簡單說說事務

對于上面的取錢這個事情,如果有一步出現(xiàn)了錯誤,那么就取消整個取錢的動作;簡單來說,就是取錢這7步,要么都完成,要么就啥也不做。在數(shù)據(jù)庫中,事務也是這個道理。

事務由一條或者多條sql語句組成,在事務中的操作,這些sql語句要么都執(zhí)行,要么都不執(zhí)行,這就是事務的目的。

對于事務而言,它需要滿足ACID特性,下面就簡要的說說事務的ACID特性。

    A,表示原子性;原子性指整個數(shù)據(jù)庫事務是不可分割的工作單位。只有使事務中所有的數(shù)據(jù)庫操作都執(zhí)行成功,整個事務的執(zhí)行才算成功。事務中任何一個sql語句執(zhí)行失敗,那么已經(jīng)執(zhí)行成功的sql語句也必須撤銷,數(shù)據(jù)庫狀態(tài)應該退回到執(zhí)行事務前的狀態(tài);
    C,表示一致性;也就是說一致性指事務將數(shù)據(jù)庫從一種狀態(tài)轉變?yōu)榱硪环N一致的狀態(tài),在事務開始之前和事務結束以后,數(shù)據(jù)庫的完整性約束沒有被破壞;
    I,表示隔離性;隔離性也叫做并發(fā)控制、可串行化或者鎖。事務的隔離性要求每個讀寫事務的對象與其它事務的操作對象能相互分離,即該事務提交前對其它事務都不可見,這通常使用鎖來實現(xiàn);
    D,持久性,表示事務一旦提交了,其結果就是永久性的,也就是數(shù)據(jù)就已經(jīng)寫入到數(shù)據(jù)庫了,如果發(fā)生了宕機等事故,數(shù)據(jù)庫也能將數(shù)據(jù)恢復。

總結了一些事務的基本概念,在MySQL中,事務還是分為很多中的,下面就來看看到底有哪些事務。
有哪些事務

你能想象到嗎?就這么個破事務還會分以下這么多種:

  1.     扁平事務;
  2.     帶有保存點的扁平事務;
  3.     鏈事務;
  4.     嵌套事務;
  5.     分布式事務。

現(xiàn)在就來對這些事務從概念的層面上進行簡單的總結一下。

    扁平事務
    扁平事務是最簡單的一種,也是實際開發(fā)中使用的最多的一種事務。在這種事務中,所有操作都處于同一層次,最常見的方式如下:

   BEGIN WORK
     Operation 1
     Operation 2
     Operation 3
     ...
     Operation N
   COMMIT WORK

    或者是這種:

   BEGIN WORK
     Operation 1
     Operation 2
     Operation 3
     ...
     Operation N
     (Error Occured)
   ROLLBACK WORK

    扁平事務的主要缺點是不能提交或回滾事務的某一部分,或者分幾個獨立的步驟去提交。比如有這樣的一個例子,我從呼和浩特去深圳,為了便宜,我可能這么干:

   BEGIN WORK
     Operation1:呼和浩特---火車--->北京
     Operation2:北京---飛機--->深圳
   ROLLBACK WORK

    但是,如果Operation1,從呼和浩特到北京的火車晚點了,錯過了航班,怎么辦?感覺扁平事務的特性,那我就需要回滾,我再回到呼和浩特,那么這樣成本是不是也太高了啊,所以就有了下面的第二種事務——帶有保存點的扁平事務。
    帶有保存點的扁平事務
    這種事務除了支持扁平事務支持的操作外,允許在事務執(zhí)行過程中回滾到同一事務中較早的一個狀態(tài),這是因為可能某些事務在執(zhí)行過程中出現(xiàn)的錯誤并不會對所有的操作都無效,放棄整個事務不合乎要求,開銷也太大。保存點用來通知系統(tǒng)應該記住事務當前的狀態(tài),以便以后發(fā)生錯誤時,事務能回到該狀態(tài)。
    鏈事務
    鏈事務,就是指回滾時,只能恢復到最近一個保存點;而帶有保存點的扁平事務則可以回滾到任意正確的保存點。
    嵌套事務
    看下面這個,你就能明白了,啥是嵌套事務:

   BEGIN WORK
     SubTransaction1:
         BEGIN WORK
           SubOperationX
         COMMIT WORK
     SubTransaction2:
         BEGIN WORK
           SubOperationY
         COMMIT WORK
     ...
     SubTransactionN:
         BEGIN WORK
           SubOperationN
         COMMIT WORK
   COMMIT WORK

    這就是嵌套事務,在事務中再嵌套事務,位于根節(jié)點的事務稱為頂層事務。事務的前驅稱為父事務,其它事務稱為子事務。事務的前驅稱為父事務,事務的下一層稱為子事務。

    子事務既可以提交也可以回滾,但是它的提交操作并不馬上生效,除非由其父事務提交。因此就可以確定,任何子事務都在頂層事務提交后才真正的被提交了。同理,任意一個事務的回滾都會引起它的所有子事務一同回滾。
    分布式事務
    分布式事務通常是指在一個分布式環(huán)境下運行的扁平事務,因此需要根據(jù)數(shù)據(jù)所在位置訪問網(wǎng)絡中的不同節(jié)點,比如:通過建設銀行向招商銀行轉賬,建設銀行和招商銀行肯定用的不是同一個數(shù)據(jù)庫,同時二者的數(shù)據(jù)庫也不在一個網(wǎng)絡節(jié)點上,那么當用戶跨行轉賬,就是通過分布式事務來保證數(shù)據(jù)的ACID的。

MySQL中使用事務

理論總結的再好,終歸都要通過實踐來進行理解。下面就來說說MySQL中是如何使用事務的。

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

來看看我們可以使用哪些事務控制語句。

  1.     BEGIN或START TRANSACTION;顯示地開啟一個事務;
  2.     COMMIT;也可以使用COMMIT WORK,不過二者是等價的。COMMIT會提交事務,并使已對數(shù)據(jù)庫進行的所有修改稱為永久性的;
  3.     ROLLBACK;有可以使用ROLLBACK WORK,不過二者是等價的?;貪L會結束用戶的事務,并撤銷正在進行的所有未提交的修改;
  4.     SAVEPOINT identifier;SAVEPOINT允許在事務中創(chuàng)建一個保存點,一個事務中可以有多個SAVEPOINT;
  5.     RELEASE SAVEPOINT identifier;刪除一個事務的保存點,當沒有指定的保存點時,執(zhí)行該語句會拋出一個異常;
  6.     ROLLBACK TO identifier;把事務回滾到標記點;
  7.     SET TRANSACTION;用來設置事務的隔離級別。InnoDB存儲引擎提供事務的隔離級別有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ和SERIALIZABLE。

這些不用你“管”

有的時候有些SQL語句會產(chǎn)生一個隱式的提交操作,即執(zhí)行完成這些語句后,會有一個隱式的COMMIT操作。有以下SQL語句,不用你去“管”:

  •     DDL語句,ALTER DATABASE、ALTER EVENT、ALTER PROCEDURE、ALTER TABLE、ALTER VIEW、CREATE TABLE、DROP TABLE、RENAME TABLE、TRUNCATE TABLE等;
  •     修改MYSQL架構的語句,CREATE USER、DROP USER、GRANT、RENAME USER、REVOKE、SET PASSWORD;
  •     管理語句,ANALYZE TABLE、CACHE INDEX、CHECK TABLE、LOAD INDEX INTO CACHE、OPTIMIZE TABLE、REPAIR TABLE等。

以上的這些SQL操作都是隱式的提交操作,不需要手動顯式提交。
事務的隔離級別

上面也說到了SET TRANSACTION用來設置事務的隔離級別。那事務的隔離級別是什么東東?

    在數(shù)據(jù)庫操作中,為了有效保證并發(fā)讀取數(shù)據(jù)的正確性,提出的事務隔離級別。

InnoDB存儲引擎提供事務的隔離級別有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ和SERIALIZABLE。這些隔離級別之間的區(qū)別如下:

2015413170207554.jpg (782×217)

  •     臟讀:一個事務讀取到了另外一個事務沒有提交的數(shù)據(jù);
  •     比如:事務T1更新了一行記錄的內容,但是并沒有提交所做的修改。事務T2讀取到了T1更新后的行,然后T1執(zhí)行回滾操作,取消了剛才所做的修改?,F(xiàn)在T2所讀取的行就無效了;
  •     不可重復讀:在同一事務中,兩次讀取同一數(shù)據(jù),得到內容不同;
  •     比如:事務T1讀取一行記錄,緊接著事務T2修改了T1剛才讀取的那一行記錄。然后T1又再次讀取這行記錄,發(fā)現(xiàn)與剛才讀取的結果不同。這就稱為“不可重復”讀,因為T1原來讀取的那行記錄已經(jīng)發(fā)生了變化;
  •     幻讀:同一事務中,用同樣的操作讀取兩次,得到的記錄數(shù)不相同;
  •     比如:事務T1讀取一條指定的WHERE子句所返回的結果集。然后事務T2新插入 一行記錄,這行記錄恰好可以滿足T1所使用的查詢條件中的WHERE子句的條件。然后T1又使用相同的查詢再次對表進行檢索,但是此時卻看到了事務T2剛才插入的新行。這個新行就稱為“幻像”,因為對T1來說這一行就像突然出現(xiàn)的一樣。

隔離級別越低,事務請求的鎖越少或保持鎖的時間就越短。InnoDB存儲引擎默認的支持隔離級別是REPEATABLE READ;在這種默認的事務隔離級別下已經(jīng)能完全保證事務的隔離性要求,即達到SQL標準的SERIALIZABLE級別隔離。

我們可以可以用SET TRANSACTION語句改變單個會話或者所有新進連接的隔離級別。它的語法如下:

SET [SESSION | GLOBAL] TRANSACTION ISOLATION LEVEL {READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE}

注意:默認的行為(不帶session和global)是為下一個(未開始)事務設置隔離級別。如果使用GLOBAL關鍵字,語句在全局對從那點開始創(chuàng)建的所有新連接(除了不存在的連接)設置默認事務級別。你需要SUPER權限來做這個。使用SESSION 關鍵字為將來在當前連接上執(zhí)行的事務設置默認事務級別。 任何客戶端都能自由改變會話隔離級別(甚至在事務的中間),或者為下一個事務設置隔離級別。

mysql> set session transaction isolation level repeatable read;
Query OK, 0 rows affected (0.00 sec)

mysql> select @@tx_isolation;
+-----------------+
| @@tx_isolation |
+-----------------+
| REPEATABLE-READ |
+-----------------+
1 row in set (0.00 sec)

總結

這篇文章,基本上都是理論概念的堆積,實戰(zhàn)的東西基本沒有。但是,這些都不是問題,這也無法阻擋這篇文章成為一篇讀者喜歡的文章,是吧。好了,這篇關于MySQL中事務的文章就到此結束,以后如果有新的東西,就接著總結。

相關文章

  • 淺析Mysql 中如何導出數(shù)據(jù)

    淺析Mysql 中如何導出數(shù)據(jù)

    MySQL中你可以使用SELECT…INTO OUTFILE語句來簡單的導出數(shù)據(jù)到文本文件上,這篇文章給大家介紹了Mysql 中如何導出數(shù)據(jù),感興趣的朋友跟隨小編一起看看吧
    2023-11-11
  • Windows版mysql?8.0.28?安裝配置方法圖文教程

    Windows版mysql?8.0.28?安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了Windows版mysql?8.0.28?安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • MySQL數(shù)據(jù)庫主從復制延時超長的解決方法

    MySQL數(shù)據(jù)庫主從復制延時超長的解決方法

    這篇文章主要給大家介紹了關于MySQL數(shù)據(jù)庫主從復制延時超長的解決方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用MySQL具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-06-06
  • mysql三張表連接建立視圖

    mysql三張表連接建立視圖

    本篇文章給大家分享了mysql三張表連接建立視圖的相關知識點,有需要的朋友可以參考下。
    2018-06-06
  • mysql 5.7.18 安裝配置方法圖文教程(CentOS7)

    mysql 5.7.18 安裝配置方法圖文教程(CentOS7)

    這篇文章主要為大家詳細介紹了CentOS 7下mysql 5.7.18 安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • mysql報錯RSA?private?key?file?not?found的解決方法

    mysql報錯RSA?private?key?file?not?found的解決方法

    當MySQL報錯RSA?private?key?file?not?found時,可能是由于MySQL的RSA私鑰文件丟失或者損壞導致的,此時可以重新生成RSA私鑰文件,以解決這個問題
    2023-06-06
  • MYSQL性能優(yōu)化分享(分庫分表)

    MYSQL性能優(yōu)化分享(分庫分表)

    MYSQL性能優(yōu)化之分庫分表與不停機修改mysql表結構,需要的朋友可以參考下
    2012-02-02
  • mysql高級學習之索引的優(yōu)劣勢及規(guī)則使用

    mysql高級學習之索引的優(yōu)劣勢及規(guī)則使用

    這篇文章主要給大家介紹了關于mysql高級學習之索引的優(yōu)劣勢及規(guī)則使用的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • MySql游標的使用實例

    MySql游標的使用實例

    這篇文章主要介紹了MySql游標,需要的朋友可以參考下
    2014-06-06
  • MySQL 5.7.43下載安裝配置的超詳細教程

    MySQL 5.7.43下載安裝配置的超詳細教程

    這篇文章主要介紹了MySQL 5.7.43下載安裝配置的超詳細教程,本文通過實例圖文結合的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的幫助,需要的朋友可以參考下
    2023-09-09

最新評論