搜尋
首頁資料庫mysql教程如何理解spring事務及聲明式事務的使用

本篇文章帶給大家的內容是關於如何理解spring事務及聲明式事務的使用,包括數據庫中的事物隔離級別,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。

spring事務及聲明式事務的使用

(同學們,開始複習大學還給老師的資料庫知識啦!!)

事務:存取並可能更新資料庫中各種資料項目的一個程式執行單元(unit)。

事務有四個屬性:(ACID)

原子性:一個事務是一個不可分割的工作單元,事務中包含的諸操作要么都做,要么都不做。

一致性;交易必須是使資料庫從一個一致性狀態變成另一個一致性狀態。一致性與原子性使密切相關的。

隔離性:一個交易的執行不能被其他事物幹擾。即一個事務內部操作及使用的資料對並發的其他事物是隔離的,並發執行的各個事務之間不能相互幹擾。

持久性:持久性也稱永久性,指一個交易一旦提交,它對資料庫中資料的改變就應該永久的。

交易目的:為了讓資料保持一致性和完整性。

一致性:一個業務鏈的資料狀態是一致的,不能部分改變部分不改變。

完整性:一個業務鏈的資料是完整的,要麼一起完成一起失敗,不能部分寫入成功,部分寫入失敗。

簡單理解事務的一致性和完整性就是要嘛一起活,要嘛一起死,不能獨活。 (像是淒慘的愛情……^ _ ^)

資料庫中的事物隔離等級

在了解事務隔離等級之前,先來了解資料中經常發生的可能導致業務邏輯失敗的幾種情況。

髒讀

當一個事務正在存取數據,並且對數據進行了修改,並且還沒有提交到資料庫中;這時另一個事務也訪問了這個數據,然後使用了這個數據。

例如:張三的銀行帳戶現在有1000,現在張三存入了200,那麼在張三點擊提交的時候,他媳婦(辛苦的張三在給媳婦存零用錢)在商場購物花了500。張三查看餘額發現只有500了(張三懵逼了。。)。然後兩人為了200吵了起來。以上就是脹讀引起一場家庭大戰。

無法重複讀取

無法重複讀取:一個交易內,多次讀同一個資料。在這個事務還沒結束時,另一個事務也存取了該資料。在第一個事務的兩次讀資料間,由於第二個事務的修改,第一事務兩次讀到的資料可能不一樣。這樣就發生了一個事務內兩次讀到的資料是不一樣的。 (即不能讀到相同的資料)

幻讀

一個事務對一個表中的資料進行了修改,這種修改涉及到表中的全部資料行,同時第二個事務向表中插入一行新資料。就會發生操作第一個交易的使用者發現表中還有沒有修改的資料行。就好像發生了幻覺一樣。

spring的五種隔離級別

ISOLATION_DEFAULT

#表示底層資料庫的預設隔離級別,對大部分資料庫而言通常值是:ISOLATION _READ _COMMITTED

#ISOLATION _READ _UNCOMMITTED

表示一個交易可以讀取另一交易修改但還沒有提交的數據,不能防止髒讀和不可重複讀。

ISOLATION _READ _COMMITTED

一個交易只能讀取另一個交易已經提交的數據,可以防止髒讀,但是不能防止不可重複讀。 (大多數情況的建議值)

ISOLATION _REPEATABLE _READ

一個交易在整個過程中可以重複執行某個查詢,並且每次傳回的記錄都相同。即使在多次查詢之間有新增的資料滿足該查詢,這些新增的記錄也會被忽略。可防止髒讀和不可重複讀。

ISOLATION _SERIALIZBLE

所有交易依序逐一執行,這樣交易之間就完全不可能產生幹擾。可防止髒讀,不可重複讀,幻讀。

事務的傳播性(spring提供了七個)

是指事務之間的關係,例如一個事務中含有另一個事務,那麼傳播性用來確定相互的執行。

TransationDefinition.PROPAGETION.REQUIRED

如果目前存在事務,則加入該事務;如果目前沒有事務,則建立一個新的事務。
spring中的預設事務。適合絕大多數情況。

TransationDefinition.PROPAGETION.REQUIRED_NEW

建立一個新的事務,如果目前存在事務,則把目前事務掛起。
意思是創造一個新的事務,和原來的事務沒有任何關係。

TransationDefinition.PROPAGETION.SUPPORTS

如果目前存在事務,則加入該事務;如果目前沒有事務,則以非事務的方式繼續運作。
這種方式很隨意,沒有就沒有,有就有,有點無所謂的態度。

TransationDefinition.PROPAGATION.NOT_SUPPORTED

以非交易的方式運行,如果目前存在事務,則把目前交易掛起。
這種方式非常強硬,沒有就沒有,有也不支持,掛起來,不管它。

TransationDefinition.PROPAGETION_NEVER

#以非交易的方式運行,如果目前存在事務,則拋出例外。
這種方式更加強硬,沒有就沒有,反而報錯,他對大家宣稱:我從不支持事務。

TransationDefinition.PROPAGETION_MANDATORY

如果目前有事務,則加入該交易;如果目前沒有事務,則拋出例外。
這種方式可以說是最強硬的,沒有事務就直接報錯,它對全世界說:我必須要有事務。

TransationDefinition.PROPAGETION_NESTED

如果目前存在事務,則建立一個交易作為目前交易的巢狀事務來運作;如果目前沒有事務,則該取值等價於
TransationDefinition .PROPAGETION_REQUIRED

聲明式交易

使用

#現在來看在springboot中,如果使用宣告式交易:

@Transactional
public void save(Object ob){

}

只要在方法上增加@ Transactional註解方法就可以被事務管理起來。

原始碼

看一下註解Transactional的原始碼:

@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Inherited
@Documented
public @interface Transactional {

@AliasFor("transactionManager")
String value() default "";


@AliasFor("value")
String transactionManager() default "";

Propagation propagation() default Propagation.REQUIRED;

Isolation isolation() default Isolation.DEFAULT;

int timeout() default TransactionDefinition.TIMEOUT_DEFAULT;


boolean readOnly() default false;

Class<? extends Throwable>[] rollbackFor() default {};


String[] rollbackForClassName() default {};

Class<? extends Throwable>[] noRollbackFor() default {};


String[] noRollbackForClassName() default {};

}

預設值

readOnly : 是否僅僅只讀。預設讀寫都可以

timeout : 交易逾時時間,預設沒有逾時時間

isolation: 交易的隔離等級預設:TransactionDefinition.ISOLATION_DEFAULT(見上文隔離等級)

propagation :交易的傳播屬性預設:TransactionDefinition.PROPAGATION_REQUIRED

#注意事項

  • ##註解應該只應用到public方法上

  • #自呼叫問題:如果類別中沒有註解方法呼叫有註解的方法,那麼外部在呼叫沒有註解的方法時,有註解的方法不會產生交易

以上是如何理解spring事務及聲明式事務的使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
您什麼時候應該使用複合索引與多個單列索引?您什麼時候應該使用複合索引與多個單列索引?Apr 11, 2025 am 12:06 AM

在數據庫優化中,應根據查詢需求選擇索引策略:1.當查詢涉及多個列且條件順序固定時,使用複合索引;2.當查詢涉及多個列但條件順序不固定時,使用多個單列索引。複合索引適用於優化多列查詢,單列索引則適合單列查詢。

如何識別和優化MySQL中的慢速查詢? (慢查詢日誌,performance_schema)如何識別和優化MySQL中的慢速查詢? (慢查詢日誌,performance_schema)Apr 10, 2025 am 09:36 AM

要優化MySQL慢查詢,需使用slowquerylog和performance_schema:1.啟用slowquerylog並設置閾值,記錄慢查詢;2.利用performance_schema分析查詢執行細節,找出性能瓶頸並優化。

MySQL和SQL:開發人員的基本技能MySQL和SQL:開發人員的基本技能Apr 10, 2025 am 09:30 AM

MySQL和SQL是開發者必備技能。 1.MySQL是開源的關係型數據庫管理系統,SQL是用於管理和操作數據庫的標準語言。 2.MySQL通過高效的數據存儲和檢索功能支持多種存儲引擎,SQL通過簡單語句完成複雜數據操作。 3.使用示例包括基本查詢和高級查詢,如按條件過濾和排序。 4.常見錯誤包括語法錯誤和性能問題,可通過檢查SQL語句和使用EXPLAIN命令優化。 5.性能優化技巧包括使用索引、避免全表掃描、優化JOIN操作和提升代碼可讀性。

描述MySQL異步主奴隸複製過程。描述MySQL異步主奴隸複製過程。Apr 10, 2025 am 09:30 AM

MySQL異步主從復制通過binlog實現數據同步,提升讀性能和高可用性。 1)主服務器記錄變更到binlog;2)從服務器通過I/O線程讀取binlog;3)從服務器的SQL線程應用binlog同步數據。

mysql:簡單的概念,用於輕鬆學習mysql:簡單的概念,用於輕鬆學習Apr 10, 2025 am 09:29 AM

MySQL是一個開源的關係型數據庫管理系統。 1)創建數據庫和表:使用CREATEDATABASE和CREATETABLE命令。 2)基本操作:INSERT、UPDATE、DELETE和SELECT。 3)高級操作:JOIN、子查詢和事務處理。 4)調試技巧:檢查語法、數據類型和權限。 5)優化建議:使用索引、避免SELECT*和使用事務。

MySQL:數據庫的用戶友好介紹MySQL:數據庫的用戶友好介紹Apr 10, 2025 am 09:27 AM

MySQL的安裝和基本操作包括:1.下載並安裝MySQL,設置根用戶密碼;2.使用SQL命令創建數據庫和表,如CREATEDATABASE和CREATETABLE;3.執行CRUD操作,使用INSERT,SELECT,UPDATE,DELETE命令;4.創建索引和存儲過程以優化性能和實現複雜邏輯。通過這些步驟,你可以從零開始構建和管理MySQL數據庫。

InnoDB緩衝池如何工作,為什麼對性能至關重要?InnoDB緩衝池如何工作,為什麼對性能至關重要?Apr 09, 2025 am 12:12 AM

InnoDBBufferPool通過將數據和索引頁加載到內存中來提升MySQL數據庫的性能。 1)數據頁加載到BufferPool中,減少磁盤I/O。 2)臟頁被標記並定期刷新到磁盤。 3)LRU算法管理數據頁淘汰。 4)預讀機制提前加載可能需要的數據頁。

MySQL:初學者的數據管理易用性MySQL:初學者的數據管理易用性Apr 09, 2025 am 12:07 AM

MySQL適合初學者使用,因為它安裝簡單、功能強大且易於管理數據。 1.安裝和配置簡單,適用於多種操作系統。 2.支持基本操作如創建數據庫和表、插入、查詢、更新和刪除數據。 3.提供高級功能如JOIN操作和子查詢。 4.可以通過索引、查詢優化和分錶分區來提升性能。 5.支持備份、恢復和安全措施,確保數據的安全和一致性。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器