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

Spring Boot項目使用Flyway的詳細教程

 更新時間:2020年07月25日 09:12:06   作者:dreamingodd  
這篇文章主要介紹了Spring Boot項目使用Flyway,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

Purpose

開發(fā)人員在合作的時候經(jīng)常遇到以下場景:

1.開發(fā)人員A在自己的本地數(shù)據(jù)庫做了一些表結(jié)構(gòu)的改動,并根據(jù)這些改動調(diào)整了DAO層的代碼,然后將代碼上傳到svn或git等版本控制服務器上。此時如果開發(fā)人員B拉取了A的代碼改動,在運行項目的時候很可能會報錯,因為B的本地SQL數(shù)據(jù)庫并沒有修改。

2.在項目上線的時候,當服務器拉取的版本控制服務器的最新修改后,必須同時運行SQL數(shù)據(jù)庫的修改腳本,如果忘了跑數(shù)據(jù)庫腳本,那么會出現(xiàn)嚴重的問題。

傳統(tǒng)的解決方案就是在一個固定的文件夾中,將需要跑的SQL腳本放在里面。開發(fā)人員在合作的時候,A修改了數(shù)據(jù)庫,在B遇到問題的時候,可能需要交流溝通一下,去跑需要的腳本。在項目上線的過程中,也是運維人員在規(guī)定的文件夾中,找到需要跑的SQL腳本。運行它們。

Flyway等migration工具就是要把開發(fā)人員和運維人員從以上這些場景的繁瑣工作中解放出來,如果使用maven的話,那么在項目編譯(SpringBoot運行Application)的時候,SQL數(shù)據(jù)庫的改動就自動進入數(shù)據(jù)庫,只要啟動成功,開發(fā)或者運維人員對SQL數(shù)據(jù)庫的migrate過程是無感知的,項目依然可以照常運行。

Technical Background

To read and practice this document, user ought to be able to develop projects via git, SpringBoot and MySQL.

Instructions - Run Demo

1.下載demo源碼:

git clone https://git.oschina.net/dreamingodd/spring-boot-flyway-demo.git

2.使用Intellij或Eclipse import existing maven project。

3.在本地mysql console中運行:

create database flyway_test;
use flyway_test;

4.修改配置文件,將username和password改成本地MySQL數(shù)據(jù)庫的。

5.運行FlywayTestApplication類。

6.在mysql console中運行

show tables;

即可看到以下結(jié)果:

(schema_version表保存了數(shù)據(jù)庫版本信息,哪些腳本已經(jīng)被執(zhí)行,先不用管)

7.一張demo表被自動創(chuàng)建出來了。

What Happened

以上過程是如何實現(xiàn)的呢?

Flyway在maven項目編譯(SpringBoot運行Application)的時候,自動掃描resources/db/migration目錄下的文件,

打開V1_demo.sql:

就是剛剛自動運行的SQL腳本。添加腳本的話,依次使用V2__XXX.sql,V3__XXX.sql,以此類推,腳本中使用正常的SQL語句即可,沒有任何學習負擔。

這樣,在開發(fā)人員合作以及項目部署的時候,F(xiàn)lyway就起到了加強自動化部署、實踐持續(xù)交付等作用。

Instruction - Use in Current Project

那么如何在已經(jīng)開發(fā)了一段時間的項目中使用Flyway呢?

1.Maven配置

<dependencies>中加上

<dependency>
  <groupId>org.flywaydb</groupId>
  <artifactId>flyway-core</artifactId>
  <version>4.0.3</version>
</dependency>

<build>中加上

<plugin>
 <groupId>org.flywaydb</groupId>
 <artifactId>flyway-maven-plugin</artifactId>
 <version>4.0.3</version>
</plugin>

2.application.properties配置

flyway.baselineOnMigrate=true

如果是application.yml,則為

flyway.baselineOnMigrate: true

3.在resources/db/migration中添加V1__XXX.sql,mvn compile(運行Application)即可看到SQL腳本運行結(jié)果。(注意V1后面是兩個下劃線)

Appendix

1.出現(xiàn)錯誤的解決方法:

如果你的SQL腳本運行失敗,到schema_version表中刪除最新一條數(shù)據(jù),

比如我故意寫一個錯誤的SQL語句到V2__demo2.sql,運行mvn compile(運行Application)。

可以看到最新一條的success列為false。

如果部分成功了,要手動rollback,修改SQL腳本正確后再次mvn compile(運行Application)。

2.更多信息請訪問官網(wǎng):https://flywaydb.org/

到此這篇關(guān)于Spring Boot項目使用Flyway的文章就介紹到這了,更多相關(guān)Spring Boot使用Flyway內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java?Mybatis使用resultMap時,屬性賦值順序錯誤的巨坑

    Java?Mybatis使用resultMap時,屬性賦值順序錯誤的巨坑

    這篇文章主要介紹了Java?Mybatis使用resultMap時,屬性賦值順序錯誤的巨坑,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • Springboot實現(xiàn)前后端分離excel下載

    Springboot實現(xiàn)前后端分離excel下載

    這篇文章主要介紹了Springboot實現(xiàn)前后端分離excel下載,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Spring?IOC中對象的創(chuàng)建、策略及銷毀時機和生命周期詳解

    Spring?IOC中對象的創(chuàng)建、策略及銷毀時機和生命周期詳解

    這篇文章主要介紹了Spring?IOC中對象的創(chuàng)建、策略及銷毀時機和生命周期詳解,Spring默認使用類的空參構(gòu)造方法創(chuàng)建bean,假如類沒有空參構(gòu)造方法,將無法完成bean的創(chuàng)建,需要的朋友可以參考下
    2023-08-08
  • java和Spring中觀察者模式的應用詳解

    java和Spring中觀察者模式的應用詳解

    這篇文章主要介紹了java和Spring中觀察者模式的應用,,具有一定的參考價值,感興趣的可以了解一下,希望能夠給你帶來幫助
    2021-10-10
  • 在springboot中對kafka進行讀寫的示例代碼

    在springboot中對kafka進行讀寫的示例代碼

    本篇文章主要介紹了在springboot中對kafka進行讀寫的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • idea數(shù)據(jù)庫驅(qū)動下載失敗的問題及解決

    idea數(shù)據(jù)庫驅(qū)動下載失敗的問題及解決

    這篇文章主要介紹了idea數(shù)據(jù)庫驅(qū)動下載失敗的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • SpringCloud微服務之Config知識總結(jié)

    SpringCloud微服務之Config知識總結(jié)

    今天帶大家學習SpringCloud微服務中的Config的相關(guān)知識,文中有非常詳細的介紹,對正在學習SpringCloud微服務的小伙伴們有很好地幫助,需要的朋友可以參考下
    2021-05-05
  • Spring AOP基本概念

    Spring AOP基本概念

    這篇文章主要為大家詳細介紹了spring基礎(chǔ)概念AOP與動態(tài)代理,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能給你帶來幫助
    2021-07-07
  • java中實現(xiàn)四則運算代碼

    java中實現(xiàn)四則運算代碼

    本文給大家分享了幾個java中實現(xiàn)四則運算的代碼,有個人的也有網(wǎng)友的,代碼寫的不是很好,難免會有BUG,忘發(fā)現(xiàn)BUG的親們能提醒我下,好讓我改進
    2015-08-08
  • Spring與Hibernate整合事務管理的理解

    Spring與Hibernate整合事務管理的理解

    這篇文章主要介紹了Spring與Hibernate整合事務管理的理解的相關(guān)資料,需要的朋友可以參考下
    2016-09-09

最新評論