Flyway的簡(jiǎn)單介紹及使用詳解
一、開發(fā)時(shí)管理數(shù)據(jù)庫(kù)遇到的問(wèn)題:
現(xiàn)在開發(fā)一般都是團(tuán)隊(duì)開發(fā),這樣就會(huì)出現(xiàn)項(xiàng)目同步的問(wèn)題,代碼同步可以通過(guò)SVN工具管理起來(lái),那數(shù)據(jù)庫(kù)同步怎么辦呢?理想的情況下,在開發(fā)新項(xiàng)目的時(shí)候會(huì)首先把業(yè)務(wù)理清楚,把數(shù)據(jù)庫(kù)表設(shè)計(jì)好,然后將數(shù)據(jù)庫(kù)交給專門的人員維護(hù),也就不存在數(shù)據(jù)庫(kù)同步的問(wèn)題了。但實(shí)際情況呢?需求從項(xiàng)目開始到項(xiàng)目結(jié)束一直在變,很多公司就沒(méi)有專門的數(shù)據(jù)庫(kù)維護(hù)人員,數(shù)據(jù)庫(kù)大家都在操作,都在修改,如果團(tuán)隊(duì)之間溝通及時(shí)還好,大家每次更新代碼后順便也更新一下數(shù)據(jù)庫(kù),如果溝通不及時(shí),呵呵(大家自行腦補(bǔ))。。。這樣數(shù)據(jù)庫(kù)不同步的問(wèn)題就凸顯出來(lái)了。
二、Flyway 的簡(jiǎn)單介紹:
1、概念:
Flyway是獨(dú)立于數(shù)據(jù)庫(kù)的應(yīng)用、管理并跟蹤數(shù)據(jù)庫(kù)變更的數(shù)據(jù)庫(kù)版本管理工具。用通俗的話講,F(xiàn)lyway可以像SVN管理不同人的代碼那樣,管理不同人的sql腳本,從而做到數(shù)據(jù)庫(kù)同步。
2、支持的數(shù)據(jù)庫(kù)類型:
Oracle, SQL Server, SQL Azure, DB2, DB2 z/OS, MySQL (including Amazon RDS), MariaDB, Google Cloud SQL, PostgreSQL (including Amazon RDS and Heroku), Redshift, Vertica, H2, Hsql, Derby, SQLite, SAP HANA, solidDB, Sybase ASE and Phoenix。
3、sql腳本的命名規(guī)范:
V+版本號(hào)(版本號(hào)的數(shù)字間以"."或"_"分隔開)+雙下劃線(用來(lái)分隔版本號(hào)和描述)+文件描述+后綴名,例如:V2017.9.30__Update.sql。
注:版本號(hào)不能相同!
4、Flyway讀取sql腳本的默認(rèn)位置:
項(xiàng)目的源文件夾下的db/migration目錄。
5、指令:
一共就6個(gè)基本指令:migrate、clean、info、validate、baseline、repair。
三、Flyway 的優(yōu)勢(shì):
1、不僅支持sql 腳本,還支持Java 代碼直接操作數(shù)據(jù)庫(kù)(flyway-core-x.x.x.jar);
2、有Maven 插件;
3、支持命令行;
4、與Spring 框結(jié)合,很方便地實(shí)現(xiàn)應(yīng)用啟動(dòng)時(shí)自動(dòng)檢查并升級(jí)數(shù)據(jù)庫(kù)的功能。
四、Flyway命令行工具的使用:
1、解壓下載flyway-commandlin 版本并解壓到本地,結(jié)構(gòu)圖如下:
2、將sql腳本放在Flyway默認(rèn)的db/migration目錄下,如果放在其他位置需要修改conf/flyway.conf文件中的flyway.locations。
3、根據(jù)自己的情況修改conf/flyway.conf文件中的flyway.url、flyway.user、flyway.password。
4、在命令行執(zhí)行migrate命令。
五、與Maven項(xiàng)目結(jié)合使用:
1、引入依賴坐標(biāo):
<!-- flyway --> <dependency> <groupId>org.flywaydb</groupId> <artifactId>flyway-core</artifactId> <version>4.2.0</version> <dependency>
2、在src/main/resources目錄下建立存放sql版本文件的路徑dataBase/sqlite(也可以寫默認(rèn)路徑db/migration),并將sql文件放在下面。
3、增加flyway的java類:
package com.xxxxxx.flyway; import javax.sql.DataSource; import org.flywaydb.core.Flyway; public class MigrationSqlite { private DataSource dataSource; public void setDataSource(DataSource dataSource) { this.dataSource = dataSource; } public void migrate() { //初始化flyway類 Flyway flyway = new Flyway(); //設(shè)置加載數(shù)據(jù)庫(kù)的相關(guān)配置信息 flyway.setDataSource(dataSource); //設(shè)置存放flyway metadata數(shù)據(jù)的表名,默認(rèn)"schema_version",可不寫 flyway.setTable("SCHMA_VERSION"); //設(shè)置flyway掃描sql升級(jí)腳本、java升級(jí)腳本的目錄路徑或包路徑,默認(rèn)"db/migration",可不寫 flyway.setLocations("dataBase/sqlite"); //設(shè)置sql腳本文件的編碼,默認(rèn)"UTF-8",可不寫 flyway.setEncoding("UTF-8"); flyway.migrate(); } }
4、在spring中實(shí)例化第3步的java類:
<bean id="MigrationSqlite" class="com.xxxxxx.flyway.MigrationSqlite" init-method="migrate"> <property name="dataSource" ref="dataSource"></property> </bean>
從上面的bean 定義中我們可以看到,我們?yōu)閒lywayMigration 這個(gè)bean 實(shí)例注入了一個(gè)數(shù)據(jù)源,F(xiàn)lyway 的所有操作將針對(duì)這個(gè)數(shù)據(jù)源進(jìn)行;同時(shí)我們通過(guò)init-method 屬性指定了Spring 在實(shí)例化該bean 以后,主動(dòng)執(zhí)行該bean 的migrate 方法,而該方法內(nèi)會(huì)執(zhí)行Flyway 更新數(shù)據(jù)庫(kù)的操作。至此,我們達(dá)到了在應(yīng)用啟動(dòng)時(shí),Spring 實(shí)例化上下文的時(shí)候,在Spring 實(shí)例化flywayMigration 這個(gè)bean 的時(shí)候,自動(dòng)執(zhí)行Flyway 更新數(shù)據(jù)庫(kù)的操作。
5、處理Flyway 更新數(shù)據(jù)庫(kù)和代碼邏輯操作數(shù)據(jù)庫(kù)時(shí)的沖突(自己目前沒(méi)遇到,網(wǎng)上找到的,先留著備不時(shí)之需):
如果Flyway 還在更新數(shù)據(jù)庫(kù),沒(méi)有完成更新操作之前,應(yīng)用程序的其他邏輯已經(jīng)開始使用數(shù)據(jù)庫(kù)進(jìn)行其他操作了,會(huì)導(dǎo)致應(yīng)用程序產(chǎn)生很多bug ,甚至根本運(yùn)行不起來(lái)。要解決這個(gè)問(wèn)題,我們可以利用Spring 的bean 依賴原理,讓關(guān)鍵的數(shù)據(jù)庫(kù)操作bean 依賴于flywayMigration 這個(gè)bean ,達(dá)到在flywayMigration 沒(méi)有實(shí)例化完成(數(shù)據(jù)庫(kù)更新操作完成)之前,不能進(jìn)行任何其他數(shù)據(jù)庫(kù)相關(guān)操作。
<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean" depends-on="MigrationSqlite"> <property name="dataSource" ref="dataSource" /> </bean>
這樣,每次啟動(dòng)項(xiàng)目時(shí)就會(huì)自動(dòng)更新數(shù)據(jù)庫(kù),不必在為數(shù)據(jù)庫(kù)不同步煩惱了。
參考文章:
1、https://flywaydb.org/documentation/ (官網(wǎng))
2、http://casheen.iteye.com/blog/1749916
3、http://shuzheng5201314.iteye.com/blog/2044517
4、http://www.dbjr.com.cn/article/191708.htm
到此這篇關(guān)于Flyway的簡(jiǎn)單介紹及使用的文章就介紹到這了,更多相關(guān)Flyway的簡(jiǎn)單介紹及使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Git配置用戶簽名方式的拓展示例實(shí)現(xiàn)全面講解
這篇文章主要為大家介紹了Git配置用戶簽名方式的拓展示例實(shí)現(xiàn)全面講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-04-04HTTP提交方式之PUT詳細(xì)介紹及POST和PUT的區(qū)別
這篇文章主要介紹了HTTP提交方式之PUT詳細(xì)介紹及POST和PUT的區(qū)別,本文簡(jiǎn)潔易懂,需要的朋友可以參考下2014-07-07詳解SHA-256算法的原理以及C#和JS的實(shí)現(xiàn)
SHA-256 是 SHA-2 下細(xì)分出的一種算法。截止目前(2023-03)未出現(xiàn)“碰撞”案例,被視為是絕對(duì)安全的加密算法之一,本文主要介紹了SHA-256算法的原理以及C#和JS的實(shí)現(xiàn),希望對(duì)大家有所幫助2023-03-03IntelliJ IDEA下的SVN使用(傻瓜式教學(xué))
這篇文章主要介紹了IntelliJ IDEA下的SVN使用(傻瓜式教學(xué)),文中通過(guò)圖文示例介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12C++ Go語(yǔ)言實(shí)現(xiàn)將windows和linux文件刪除至回收站
這篇文章主要為大家詳細(xì)介紹了如何分別使用C++ Go語(yǔ)言實(shí)現(xiàn)將windows和linux文件刪除至回收站,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12