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

Java使用flyway實現(xiàn)腳本自動化的方法詳解

 更新時間:2023年10月27日 09:40:39   作者:生命猿于運動  
Flyway是一個開源的數(shù)據(jù)庫版本控制工具,主要用于管理數(shù)據(jù)庫的版本和變更,它可以自動化地將數(shù)據(jù)庫遷移到不同的版本,同時支持多種數(shù)據(jù)庫類型,本文給大家介紹了如何使用flyway實現(xiàn)腳本自動化,需要的朋友可以參考下

如何使用

使用Flyway,僅需將編寫的好SQL語句寫成sql腳本文件,根據(jù)版本規(guī)定填寫正確的文件名,存放到指定的目錄底下,在項目進(jìn)行啟動時即可自動掃描指定目錄底下的腳本,根據(jù)數(shù)據(jù)庫Flyway配置表進(jìn)行對比,將未執(zhí)行的腳本按順序自動執(zhí)行。

Flyway腳本遷移文件命名需要遵循以下規(guī)則:

如上圖,文件命名規(guī)范主要分為以下幾個部分:

  • 前綴:V表示版本化遷移,U表示撤銷遷移,R表示可重復(fù)遷移。
  • 下劃線:在版本號中下劃線會被.替換。
  • 分隔符:兩個下劃線,用來分隔版本號與文件描述詞
  • 描述:腳本文件內(nèi)容的簡短描述,執(zhí)行后內(nèi)容中的下劃線則會被替換為空格。

文件名版本號與文件描述內(nèi)容以兩個下劃線分隔開,命名示例:

  • V1_20231026154401__create_student_table.sql
  • V1_20231026162233__insert_student_data.sql

通常情況下我們都是直接以V前綴進(jìn)行命名,在需要進(jìn)行回退操作時,直接在腳本中寫好回退的腳本即可。

更多內(nèi)容可以參考官方文檔說明: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相關(guān)配置信息,開啟flyway腳本遷移功能:

spring:
  flyway:
    # flyway 開啟/關(guān)閉
    enabled: true
    # 當(dāng)遷移時發(fā)現(xiàn)目標(biāo)schema非空,而且?guī)в袥]有元數(shù)據(jù)的表時,是否自動執(zhí)行基準(zhǔn)遷移,默認(rèn)false.
    baseline-on-migrate: true
    # 是否允許無序的遷移,默認(rèn)false.
    out-of-order: true
    # 遷移時是否校驗,默認(rèn)為true
    validate-on-migrate: false
    # 遷移腳本的位置,默認(rèn)db/migration.
    locations: classpath:db
    # flyway 基線版本號
    baseline-version: 0
    # flyway 執(zhí)行記錄表
    table: demo_flyway_schema_history

在上面的配置中也描述了每個屬性參數(shù)的作用,上面的腳本位置配置的是locations: classpath:db,在這里我們就可以將需要進(jìn)行遷移執(zhí)行的腳本文件,按上面的命名規(guī)范配置好之后存放到此目錄下:

確認(rèn)好文件存放位置無誤之后,我們就可以直接啟動服務(wù):

如圖服務(wù)啟動成功后,我們就可以看到相關(guān)flyway執(zhí)行的日志信息,如果是首次使用flyway遷移腳本的話,那么就會自動幫我們創(chuàng)建一個flyway執(zhí)行記錄表,表結(jié)構(gòu)如下:

  • installed_rank:主鍵
  • version:版本號
  • description:文件描述
  • type:腳本類型
  • script:完整文件名
  • checksum:flyway通過特定的算法根據(jù)文件內(nèi)容計算出來的一個整數(shù),可以簡單理解為文件內(nèi)容的標(biāo)識符,如果我們在配置中開啟校驗時(validate-on-migrate=true),如果我們文件內(nèi)容有修改將計算出新的checksum與執(zhí)行過的的checksum不一致時即會報mismatch的錯誤,以此來告知開發(fā)者腳本有變動。
  • installed_by:執(zhí)行腳本的數(shù)據(jù)庫用戶
  • execution_time:執(zhí)行時間
  • success:執(zhí)行結(jié)果,0:失敗,1:成功

總結(jié)

有了這么一個腳本遷移的工具,對于開發(fā)人員也好,對運維人員也罷,都能夠減輕雙方的負(fù)擔(dān),并且減少在部署時手動去執(zhí)行腳本出錯的風(fēng)險,好的工具一直在為我們節(jié)約更多的時間,用上之后真的停不下來。

以上就是Java使用flyway實現(xiàn)腳本自動化的方法詳解的詳細(xì)內(nèi)容,更多關(guān)于Java flyway實現(xiàn)腳本自動化的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • java?11新特性HttpClient主要組件及發(fā)送請求示例詳解

    java?11新特性HttpClient主要組件及發(fā)送請求示例詳解

    這篇文章主要為大家介紹了java?11新特性HttpClient主要組件及發(fā)送請求示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • Spark Streaming編程初級實踐詳解

    Spark Streaming編程初級實踐詳解

    這篇文章主要為大家介紹了Spark Streaming編程初級實踐詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • Java數(shù)據(jù)結(jié)構(gòu)之LinkedList從鏈表到實現(xiàn)

    Java數(shù)據(jù)結(jié)構(gòu)之LinkedList從鏈表到實現(xiàn)

    LinkedList是Java中常用的數(shù)據(jù)結(jié)構(gòu)之一,實現(xiàn)了鏈表的特性,支持快速添加、刪除元素,可以用于實現(xiàn)隊列、棧、雙向隊列等數(shù)據(jù)結(jié)構(gòu)。LinkedList的內(nèi)部實現(xiàn)采用了雙向鏈表,其中每個節(jié)點都包含前驅(qū)節(jié)點和后繼節(jié)點的引用,可以直接訪問鏈表的頭尾元素
    2023-04-04
  • 創(chuàng)建SpringBoot工程并集成Mybatis的方法

    創(chuàng)建SpringBoot工程并集成Mybatis的方法

    這篇文章主要介紹了創(chuàng)建SpringBoot工程并集成Mybatis,需要的朋友可以參考下
    2018-06-06
  • java異步寫日志到文件中實現(xiàn)代碼

    java異步寫日志到文件中實現(xiàn)代碼

    這篇文章主要介紹了java異步寫日志到文件中實現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • 解決BeanUtils.copyProperties無法成功封裝的問題

    解決BeanUtils.copyProperties無法成功封裝的問題

    這篇文章主要介紹了解決BeanUtils.copyProperties無法成功封裝的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Java 實戰(zhàn)項目錘煉之在線美食網(wǎng)站系統(tǒng)的實現(xiàn)流程

    Java 實戰(zhàn)項目錘煉之在線美食網(wǎng)站系統(tǒng)的實現(xiàn)流程

    讀萬卷書不如行萬里路,只學(xué)書上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+SSM+jsp+mysql+maven實現(xiàn)一個在線美食網(wǎng)站系統(tǒng),大家可以在過程中查缺補(bǔ)漏,提升水平
    2021-11-11
  • JavaEE賬號注冊模擬網(wǎng)站郵箱激活

    JavaEE賬號注冊模擬網(wǎng)站郵箱激活

    這篇文章主要為大家詳細(xì)介紹了JavaEE賬號注冊模擬網(wǎng)站郵箱激活,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • 如何實現(xiàn)java執(zhí)行kettle并傳參數(shù)

    如何實現(xiàn)java執(zhí)行kettle并傳參數(shù)

    文章主要介紹了在審批成功后如何使用Kettle傳遞批次號參數(shù)并執(zhí)行KTR文件,同時,提到了所需的主要POM依賴,并強(qiáng)調(diào)了個人經(jīng)驗的價值,鼓勵大家參考和使用
    2025-01-01
  • 使用JMX連接JVM實現(xiàn)過程詳解

    使用JMX連接JVM實現(xiàn)過程詳解

    這篇文章主要介紹了使用JMX連接JVM實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-04-04

最新評論