1. 程式人生 > 其它 >java下實現把byte型別當作無符號byte型別使用

java下實現把byte型別當作無符號byte型別使用

技術標籤:資料庫資料庫mysqljava

事務是邏輯上的⼀組操作,要麼都執⾏,要麼都不執⾏

事務的四大特性(ACID)

  1. 原⼦性(Atomicity): 事務是最⼩的執⾏單位,不允許分割。事務的原⼦性確保動作要麼全部
    完成,要麼完全不起作⽤;
  2. ⼀致性(Consistency): 執⾏事務前後,資料保持⼀致,多個事務對同⼀個數據讀取的結果是
    相同的;
  3. 隔離性(Isolation): 併發訪問資料庫時,⼀個⽤戶的事務不被其他事務所⼲擾,各併發事務
    之間資料庫是獨⽴的;
  4. 永續性(Durability): ⼀個事務被提交之後。它對資料庫中資料的改變是持久的,即使資料
    庫發⽣故障也不應該對其有任何影響。

併發事務帶來的問題

髒讀(Dirty read): 當⼀個事務正在訪問資料並且對資料進⾏了修改,⽽這種修改還沒有提交到資料庫中,這時另外⼀個事務也訪問了這個資料,然後使⽤了這個資料。因為這個資料是還沒有提交的資料,那麼另外⼀個事務讀到的這個資料是“髒資料”。
丟失修改(Lost to modify): 指在⼀個事務讀取⼀個數據時,另外⼀個事務也訪問了該資料,那麼在第⼀個事務中修改了這個資料後,第⼆個事務也修改了這個資料。這樣第⼀個事務內的修改結果就被丟失,因此稱為丟失修改。 例如:事務1讀取某表中的資料A=20,事務2也讀取A=20,事務1修改A=A-1,事務2也修改A=A-1,最終結果A=19,事務1的修改被丟失。

不可重複讀(Unrepeatableread): 指在⼀個事務內多次讀同⼀資料。在這個事務還沒有結束
時,另⼀個事務也訪問該資料。那麼,在第⼀個事務中的兩次讀資料之間,由於第⼆個事務的修改導致第⼀個事務兩次讀取的資料可能不太⼀樣。這就發⽣了在⼀個事務內兩次讀到的資料是不⼀樣的情況,因此稱為不可重複讀。
幻讀(Phantom read): 幻讀與不可重複讀類似。它發⽣在⼀個事務(T1)讀取了⼏⾏資料,接著另⼀個併發事務(T2)插入了⼀些資料時。在隨後的查詢中,第⼀個事務(T1)就會發現多了⼀些原本不存在的記錄,就好像發⽣了幻覺⼀樣,所以稱為幻讀。

事務的四個隔離級別

READ-UNCOMMITTED(讀未提交

): 最低的隔離級別,允許讀取尚未提交的資料變更,可能會導致髒讀、幻讀或不可重複讀。
READ-COMMITTED(讀已提交): 允許讀取併發事務已經提交的資料,可以阻⽌髒讀,但是幻讀或不可重複讀仍有可能發⽣。
REPEATABLE-READ(可重複讀): 對同⼀欄位的多次讀取結果都是⼀致的,除⾮資料是被本身事務⾃⼰所修改,可以阻⽌髒讀和不可重複讀,但幻讀仍有可能發⽣。
SERIALIZABLE(序列化): 最⾼的隔離級別,完全服從ACID的隔離級別。所有的事務依次逐個執⾏,這樣事務之間就完全不可能產⽣⼲擾,也就是說,該級別可以防⽌髒讀、不可重複讀以及幻讀。效能非常差。
在這裡插入圖片描述
MySQL InnoDB 儲存引擎的預設⽀持的隔離級別是 REPEATABLE-READ(可重讀)。我們可以通過 SELECT @@tx_isolation; 命令來檢視

mysql> SELECT @@tx_isolation;
+-----------------+
| @@tx_isolation  |
+-----------------+
| REPEATABLE-READ |
+-----------------+

與 SQL 標準不同的地⽅在於 InnoDB 儲存引擎在 REPEATABLE-READ(可重讀) 事務隔離級別下使⽤的是Next-Key Lock鎖演算法,因此可以避免幻讀的產⽣。所以說InnoDB 儲存引擎的預設⽀持的隔離級別是 REPEATABLE-READ(可重讀) 已經可以完全保證事務的隔離性要求,即達到了 SQL標準的 SERIALIZABLE(可串⾏化) 隔離級別。因為隔離級別越低,事務請求的鎖越少,所以⼤部分資料庫系統的隔離級別都是 READ-COMMITTED(讀取提交內容) 。