java開發(fā)flyway的方法
FlyWay官網(wǎng):https://flywaydb.org/getstarted/firststeps/maven
Flyway做為database migration開源工具,功能上像是Git、svn這種代碼版本控制。google搜索database migration,或者針對性更強(qiáng)些搜索database migration Java,會有其它的framework、tool、甚至aws的service。因?yàn)轫?xiàng)目使用到了flyway,而且確實(shí)google中排第一位的搜索結(jié)果就是flyway,那就之后有機(jī)會再與其它方案做比較,先對flyway做下學(xué)習(xí)筆記。
數(shù)據(jù)庫版本管理工具
什么是數(shù)據(jù)庫版本管理?
做過開發(fā)的小伙伴們都知道,實(shí)現(xiàn)一個(gè)需求時(shí),一般情況下都需要設(shè)計(jì)到數(shù)據(jù)庫表結(jié)構(gòu)的修改。那么我們怎么能保證項(xiàng)目多人開發(fā)時(shí),多個(gè)數(shù)據(jù)庫環(huán)境(測試,生產(chǎn)環(huán)境)能夠保持一致呢?在沒有數(shù)據(jù)庫版本管理工具之前,需要將數(shù)據(jù)庫修改腳本拷貝到每個(gè)數(shù)據(jù)庫環(huán)境進(jìn)行執(zhí)行。而有了數(shù)據(jù)庫版本管理工具之后,程序在啟動的時(shí)候就會根據(jù)實(shí)現(xiàn)定義好的規(guī)則來進(jìn)行數(shù)據(jù)庫腳本的執(zhí)行。
使用flyway
使用環(huán)境
#用的是springboot項(xiàng)目,mysql數(shù)據(jù)庫
導(dǎo)入flayway和mysql依賴
<dependency> <groupId>org.flywaydb</groupId> <artifactId>flyway-core</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency>
創(chuàng)建數(shù)據(jù)庫腳本目錄
在resources資源目錄下創(chuàng)建db/migration目錄。
添加數(shù)據(jù)庫腳本
#腳本命名規(guī)則 V<VERSION>__<NAME>.sql,P<VERSION>__<NAME>.sql。V代表只執(zhí)行一次,P代表可以執(zhí)行多次 #VERSION代表數(shù)據(jù)庫腳本版本,NAME代表數(shù)據(jù)名稱。 #這里使用V1_test.sql,腳本內(nèi)容如下所示。 DROP TABLE IF EXISTS `role`; CREATE TABLE `role` ( `id` int(11) NOT NULL, `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, PRIMARY KEY (`id`) USING BTREE ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic; INSERT INTO `role` VALUES (1, '1');
properties文件配置
#指定數(shù)據(jù)庫腳本為UTF-8, flyway的配置有很多,有興趣的小伙伴可以去看下 spring.flyway.encoding=utf-8 #如果原來的數(shù)據(jù)庫不為空,則需要設(shè)置 spring.flyway.baseline-on-migrate=true #設(shè)置數(shù)據(jù)庫起始版本為0,默認(rèn)為1。如果你寫的sql腳本version小于等于起始版本則不會執(zhí)行。 spring.flyway.baseline-version=0 #數(shù)據(jù)源配置 spring.datasource.url=jdbc:mysql://127.0.0.1/test?useUnicode=true&characterEncoding=utf8&useSSL=false spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.username=root spring.datasource.password=123456
啟動應(yīng)用程序,查看控制臺輸出
數(shù)據(jù)庫查看
此時(shí)flyway會默認(rèn)添加一張記錄數(shù)據(jù)庫版本信息的表,每次啟動時(shí)會根據(jù)version值判斷是否需要執(zhí)行sql。
flyway是怎么執(zhí)行的?
#spring-boot-dependencies 導(dǎo)入了flyway,mysql依賴。 #spring-boot-autoconfigure 中導(dǎo)入了FlywayAutoConfiguration自動配置類
到此這篇關(guān)于java開發(fā)flyway的方法的文章就介紹到這了,更多相關(guān)java開發(fā)flyway內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于java關(guān)鍵字this和super的區(qū)別和理解
這篇文章主要給大家介紹了關(guān)于java關(guān)鍵字this和super的區(qū)別和理解的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01詳解spring batch的使用和定時(shí)器Quart的使用
spring Batch是一個(gè)基于Spring的企業(yè)級批處理框架,它通過配合定時(shí)器Quartz來輕易實(shí)現(xiàn)大批量的數(shù)據(jù)讀取或插入,并且全程自動化,無需人員管理2017-08-08idea64.exe.vmoptions文件如何設(shè)置調(diào)整VM配置文件
這篇文章主要介紹了idea64.exe.vmoptions文件如何設(shè)置調(diào)整VM配置文件問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04MyBatis中的SQL映射文件如何配置參數(shù)映射和使用方法
MyBatis 是一種開源的 Java 持久化框架,它可以自動將數(shù)據(jù)庫中的數(shù)據(jù)映射到 Java 對象中,并且使得 Java 對象可以非常方便地存儲到數(shù)據(jù)庫中,本文將介紹 MyBatis 中 SQL 映射文件的參數(shù)映射配置和使用方法,需要的朋友可以參考下2023-07-07