Java使用flyway實現(xiàn)腳本自動化的方法詳解
如何使用
使用Flyway
,僅需將編寫的好SQL語句寫成sql腳本文件,根據(jù)版本規(guī)定填寫正確的文件名,存放到指定的目錄底下,在項目進行啟動時即可自動掃描指定目錄底下的腳本,根據(jù)數(shù)據(jù)庫Flyway
配置表進行對比,將未執(zhí)行的腳本按順序自動執(zhí)行。
Flyway
腳本遷移文件命名需要遵循以下規(guī)則:
如上圖,文件命名規(guī)范主要分為以下幾個部分:
- 前綴:
V
表示版本化遷移,U
表示撤銷遷移,R
表示可重復遷移。 - 下劃線:在版本號中下劃線會被
.
替換。 - 分隔符:兩個下劃線,用來分隔版本號與文件描述詞
- 描述:腳本文件內容的簡短描述,執(zhí)行后內容中的下劃線則會被替換為空格。
文件名版本號與文件描述內容以兩個下劃線分隔開,命名示例:
- V1_20231026154401__create_student_table.sql
- V1_20231026162233__insert_student_data.sql
通常情況下我們都是直接以V
前綴進行命名,在需要進行回退操作時,直接在腳本中寫好回退的腳本即可。
更多內容可以參考官方文檔說明:https://documentation.red-gate.com/fd/migrations-184127470.html#versioned-migrations
案例分析
首先需要引入flyway依賴包:
<dependency> <groupId>org.flywaydb</groupId> <artifactId>flyway-core</artifactId> <version>6.4.1</version> </dependency>
在application.yml
文件中添加flyway
相關配置信息,開啟flyway
腳本遷移功能:
spring: flyway: # flyway 開啟/關閉 enabled: true # 當遷移時發(fā)現(xiàn)目標schema非空,而且?guī)в袥]有元數(shù)據(jù)的表時,是否自動執(zhí)行基準遷移,默認false. baseline-on-migrate: true # 是否允許無序的遷移,默認false. out-of-order: true # 遷移時是否校驗,默認為true validate-on-migrate: false # 遷移腳本的位置,默認db/migration. locations: classpath:db # flyway 基線版本號 baseline-version: 0 # flyway 執(zhí)行記錄表 table: demo_flyway_schema_history
在上面的配置中也描述了每個屬性參數(shù)的作用,上面的腳本位置配置的是locations: classpath:db
,在這里我們就可以將需要進行遷移執(zhí)行的腳本文件,按上面的命名規(guī)范配置好之后存放到此目錄下:
確認好文件存放位置無誤之后,我們就可以直接啟動服務:
如圖服務啟動成功后,我們就可以看到相關flyway
執(zhí)行的日志信息,如果是首次使用flyway
遷移腳本的話,那么就會自動幫我們創(chuàng)建一個flyway執(zhí)行記錄表,表結構如下:
- installed_rank:主鍵
- version:版本號
- description:文件描述
- type:腳本類型
- script:完整文件名
- checksum:flyway通過特定的算法根據(jù)文件內容計算出來的一個整數(shù),可以簡單理解為文件內容的標識符,如果我們在配置中開啟校驗時(
validate-on-migrate=true
),如果我們文件內容有修改將計算出新的checksum
與執(zhí)行過的的checksum
不一致時即會報mismatch
的錯誤,以此來告知開發(fā)者腳本有變動。 - installed_by:執(zhí)行腳本的數(shù)據(jù)庫用戶
- execution_time:執(zhí)行時間
- success:執(zhí)行結果,0:失敗,1:成功
總結
有了這么一個腳本遷移的工具,對于開發(fā)人員也好,對運維人員也罷,都能夠減輕雙方的負擔,并且減少在部署時手動去執(zhí)行腳本出錯的風險,好的工具一直在為我們節(jié)約更多的時間,用上之后真的停不下來。
以上就是Java使用flyway實現(xiàn)腳本自動化的方法詳解的詳細內容,更多關于Java flyway實現(xiàn)腳本自動化的資料請關注腳本之家其它相關文章!
相關文章
java?11新特性HttpClient主要組件及發(fā)送請求示例詳解
這篇文章主要為大家介紹了java?11新特性HttpClient主要組件及發(fā)送請求示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06Java數(shù)據(jù)結構之LinkedList從鏈表到實現(xiàn)
LinkedList是Java中常用的數(shù)據(jù)結構之一,實現(xiàn)了鏈表的特性,支持快速添加、刪除元素,可以用于實現(xiàn)隊列、棧、雙向隊列等數(shù)據(jù)結構。LinkedList的內部實現(xiàn)采用了雙向鏈表,其中每個節(jié)點都包含前驅節(jié)點和后繼節(jié)點的引用,可以直接訪問鏈表的頭尾元素2023-04-04創(chuàng)建SpringBoot工程并集成Mybatis的方法
這篇文章主要介紹了創(chuàng)建SpringBoot工程并集成Mybatis,需要的朋友可以參考下2018-06-06解決BeanUtils.copyProperties無法成功封裝的問題
這篇文章主要介紹了解決BeanUtils.copyProperties無法成功封裝的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06Java 實戰(zhàn)項目錘煉之在線美食網站系統(tǒng)的實現(xiàn)流程
讀萬卷書不如行萬里路,只學書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+SSM+jsp+mysql+maven實現(xiàn)一個在線美食網站系統(tǒng),大家可以在過程中查缺補漏,提升水平2021-11-11如何實現(xiàn)java執(zhí)行kettle并傳參數(shù)
文章主要介紹了在審批成功后如何使用Kettle傳遞批次號參數(shù)并執(zhí)行KTR文件,同時,提到了所需的主要POM依賴,并強調了個人經驗的價值,鼓勵大家參考和使用2025-01-01