国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Spring Boot項目使用Flyway的詳細教程

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

2020-07-25 13:52dreamingodd Java教程

這篇文章主要介紹了Spring Boot項目使用Flyway,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

Purpose

開發人員在合作的時候經常遇到以下場景:

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

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

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

Flyway等migration工具就是要把開發人員和運維人員從以上這些場景的繁瑣工作中解放出來,如果使用maven的話,那么在項目編譯(SpringBoot運行Application)的時候,SQL數據庫的改動就自動進入數據庫,只要啟動成功,開發或者運維人員對SQL數據庫的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中運行:

?
1
2
create database flyway_test;
use flyway_test;

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

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

5.運行FlywayTestApplication類。

6.在mysql console中運行

?
1
show tables;

即可看到以下結果:

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

(schema_version表保存了數據庫版本信息,哪些腳本已經被執行,先不用管)

7.一張demo表被自動創建出來了。

What Happened

以上過程是如何實現的呢?

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

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

打開V1_demo.sql:

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

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

這樣,在開發人員合作以及項目部署的時候,Flyway就起到了加強自動化部署、實踐持續交付等作用。

Instruction - Use in Current Project

那么如何在已經開發了一段時間的項目中使用Flyway呢?

1.Maven配置

<dependencies>中加上

?
1
2
3
4
5
<dependency>
  <groupId>org.flywaydb</groupId>
  <artifactId>flyway-core</artifactId>
  <version>4.0.3</version>
</dependency>

<build>中加上

?
1
2
3
4
5
<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腳本運行結果。(注意V1后面是兩個下劃線)

Appendix

1.出現錯誤的解決方法:

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

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

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

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

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

2.更多信息請訪問官網:https://flywaydb.org/

到此這篇關于Spring Boot項目使用Flyway的文章就介紹到這了,更多相關Spring Boot使用Flyway內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/dreamingodd/p/6125435.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: av免费在线观看网站 | 91麻豆精品国产91久久久资源速度 | 亚洲成av人片一区二区梦乃 | 亚洲精品系列 | 欧美在线一区二区三区 | 亚洲精品一区二区在线 | 一区福利 | 爱爱网av| 欧美日韩电影一区二区三区 | 国产二区视频 | 久久久一区二区三区 | 激情欧美一区二区三区中文字幕 | 91免费在线视频观看 | 99国产精品 | 中文字幕在线免费看 | jizzxxx日本| 国产精品成人观看视频国产奇米 | 日韩免费在线视频 | 亚洲在线 | 亚洲一级在线 | 亚洲视频精品一区 | 国产精品久久久久久久浪潮网站 | 欧美在线播放一区 | 国产成人午夜精品5599 | 日韩精品 | 欧美日韩国产一区二区 | 美日韩一区 | 欧美日韩精品久久久 | 久久久久无码国产精品一区 | 国产精品www| 欧美一区二区三区在线视频 | 蜜臀久久精品99国产精品日本 | 欧美一区永久视频免费观看 | 国产午夜精品一区二区三区免费 | 国产欧美精品 | 成a人片在线观看 | 久久久精品日本 | 日韩视频一区二区 | 91久久久久久 | 日韩精品一区二区三区 | 国产黄色小视频 |