日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

flyway版本号_数据库版本管理工具-flyway

發(fā)布時(shí)間:2024/4/13 数据库 54 豆豆
生活随笔 收集整理的這篇文章主要介紹了 flyway版本号_数据库版本管理工具-flyway 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

flyway產(chǎn)生背景

在日常開(kāi)發(fā)中,經(jīng)常遇到數(shù)據(jù)庫(kù)變更,字段增減調(diào)整,需要維護(hù)多個(gè)不同數(shù)據(jù)庫(kù)時(shí)是十分痛苦的事情.代碼可以使用svn,git等工具進(jìn)行管理,那么數(shù)據(jù)庫(kù)的版本可以使用Flyway 一款小工具,就可以大大簡(jiǎn)化這方面的工作。官方網(wǎng)站

介紹

flyway支持大部分主流的數(shù)據(jù)庫(kù),Oracle,SQL Server MySQL等;

并且擁有命令行工具,Maven,Gradle插件等;

配置簡(jiǎn)單,實(shí)用方便,支持Sql及java配置,這里寫一個(gè)簡(jiǎn)單的java配置。

需要明白的幾個(gè)概念:

版本:對(duì)數(shù)據(jù)庫(kù)的每一次變更可稱為一個(gè)版本。

遷移:Flyway把數(shù)據(jù)庫(kù)結(jié)構(gòu)從一個(gè)版本更新到另一個(gè)版本叫做遷移。

可用的遷移:Flyway的文件系統(tǒng)識(shí)別出來(lái)的遷移版本。

已經(jīng)應(yīng)用的遷移:Flyway已經(jīng)對(duì)數(shù)據(jù)庫(kù)執(zhí)行過(guò)的遷移。

使用

需要使用Flyway核心jar包;可直接下載flyway-core-3.2.1.jar。

在項(xiàng)目中創(chuàng)建文件夾 src/dbmigration, 默認(rèn)src/db/migration,可以在配置中進(jìn)行修改。

對(duì)Flyway進(jìn)行數(shù)據(jù)庫(kù)配置,這里使用spring配置文件配置,也可以使用java對(duì)象進(jìn)行配置,

然后,就完成了簡(jiǎn)單配置了,在dbmigration文件夾下創(chuàng)建sql文件,比如:V1_0_1__初始化.sql,V1_0_2__修改表.sql等,其中sql腳本文件需要按照一定的規(guī)則來(lái)命名,能夠讓flyway檢測(cè)并執(zhí)行。

命名規(guī)則也能進(jìn)行定義比如prefix、separator、suffix,默認(rèn)prefix是V(執(zhí)行一遍,并且版本號(hào)唯一,如果有重復(fù)就會(huì)報(bào)錯(cuò))或R(重復(fù)執(zhí)行,不需要版本號(hào)),separator是雙下劃線__,suffix是.sql。V開(kāi)頭+版本號(hào)+雙下劃線+描述。

新版本更改腳本,版本數(shù)字大于之前的版本就可以了。

注意

在啟動(dòng)tomcat啟動(dòng)后 加載配置文件運(yùn)行flyway組件 對(duì)數(shù)據(jù)庫(kù)版本更新,它在維護(hù)更新時(shí)會(huì)在數(shù)據(jù)庫(kù)中新建表 schame_version 用來(lái)對(duì)sql腳本版本升級(jí)進(jìn)行維護(hù),一份sql文件對(duì)應(yīng)一條數(shù)據(jù),所以對(duì)數(shù)據(jù)庫(kù)版本升級(jí)時(shí),會(huì)根據(jù)該表查詢進(jìn)行操作,如果沒(méi)有記錄,則會(huì)執(zhí)行該sql文件,如果存在數(shù)據(jù)則不執(zhí)行,在對(duì)當(dāng)前數(shù)據(jù)庫(kù)中sql腳本只會(huì)執(zhí)行一次,

如果出現(xiàn)異常例如:org.flywaydb.core.api.FlywayException: Schema “xxx” contains a failed migration to version 1.1.043 !則表示數(shù)據(jù)庫(kù)沖突,需要把表 schame_version 相應(yīng)記錄刪除,并且保證sql腳本操作不會(huì)與該數(shù)據(jù)庫(kù)沖突。每次版本更新 schame_version 都會(huì)保存運(yùn)行的結(jié)果。

總結(jié)

以上是生活随笔為你收集整理的flyway版本号_数据库版本管理工具-flyway的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。