一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

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

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

服務器之家 - 編程語言 - Java教程 - java開發(fā)flyway的方法

java開發(fā)flyway的方法

2020-07-25 12:30幕友皎敖奔乾 Java教程

這篇文章主要介紹了java開發(fā)flyway的方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

FlyWay官網(wǎng):https://flywaydb.org/getstarted/firststeps/maven

Flyway做為database migration開源工具,功能上像是Git、svn這種代碼版本控制。google搜索database migration,或者針對性更強些搜索database migration Java,會有其它的framework、tool、甚至aws的service。因為項目使用到了flyway,而且確實google中排第一位的搜索結果就是flyway,那就之后有機會再與其它方案做比較,先對flyway做下學習筆記。

數(shù)據(jù)庫版本管理工具

什么是數(shù)據(jù)庫版本管理?

做過開發(fā)的小伙伴們都知道,實現(xiàn)一個需求時,一般情況下都需要設計到數(shù)據(jù)庫表結構的修改。那么我們怎么能保證項目多人開發(fā)時,多個數(shù)據(jù)庫環(huán)境(測試,生產(chǎn)環(huán)境)能夠保持一致呢?在沒有數(shù)據(jù)庫版本管理工具之前,需要將數(shù)據(jù)庫修改腳本拷貝到每個數(shù)據(jù)庫環(huán)境進行執(zhí)行。而有了數(shù)據(jù)庫版本管理工具之后,程序在啟動的時候就會根據(jù)實現(xiàn)定義好的規(guī)則來進行數(shù)據(jù)庫腳本的執(zhí)行。

使用flyway

使用環(huán)境

#用的是springboot項目,mysql數(shù)據(jù)庫

導入flayway和mysql依賴

java" id="highlighter_879866">
?
1
2
3
4
5
6
7
8
9
10
11
12
<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ù)庫腳本

?
1
2
3
4
5
6
7
8
9
10
11
12
13
#腳本命名規(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文件配置

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#指定數(shù)據(jù)庫腳本為UTF-8, flyway的配置有很多,有興趣的小伙伴可以去看下
spring.flyway.encoding=utf-8
 
#如果原來的數(shù)據(jù)庫不為空,則需要設置
spring.flyway.baseline-on-migrate=true
 
#設置數(shù)據(jù)庫起始版本為0,默認為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

啟動應用程序,查看控制臺輸出

java開發(fā)flyway的方法

數(shù)據(jù)庫查看

java開發(fā)flyway的方法

此時flyway會默認添加一張記錄數(shù)據(jù)庫版本信息的表,每次啟動時會根據(jù)version值判斷是否需要執(zhí)行sql。

flyway是怎么執(zhí)行的?

?
1
2
#spring-boot-dependencies 導入了flyway,mysql依賴。
#spring-boot-autoconfigure 中導入了FlywayAutoConfiguration自動配置類

到此這篇關于java開發(fā)flyway的方法的文章就介紹到這了,更多相關java開發(fā)flyway內(nèi)容請搜索服務器之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/chenhaoblog/archive/2020/07/25/13375351.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 男人狂躁女人下半身 | 四虎影视在线影院在线观看观看 | 好骚好紧 | 暖暖在线日本 | 亚洲精品一线二线三线 | 亚洲国产欧美另类va在线观看 | 国产剧情一区 | 涩涩漫画免费 | 国产日韩精品一区二区三区 | 岛国在线播放v片免费 | 国产资源免费观看 | 国产成人性色视频 | 向日葵视频app下载18岁以下勿看 | 亚洲免费国产 | gay小太正初精 | 久久精品国产只有精品 | 无限在线看免费视频大全 | 国产精品区一区二区免费 | 深夜在线网址 | 亚洲国产精品一在线观看 | 欧美国产日产精品免费视频 | 波多野结衣家庭教师 | 亚洲成人黄色 | 精品无码人妻一区二区免费AV | 色综合久久中文字幕 | 日韩一级片在线观看 | 嫩草影院永久在线播放 | 成年视频在线播放 | 日韩欧美国内 | 俄罗斯freeoo性另类 | 亚洲国产视频网站 | 91亚洲在线 | 免费看全黄特黄毛片 | 国产精品理论片在线观看 | tk白丝丨vk| 91大神在线精品视频一区 | 成人网视频免费播放 | 国产精品日本一区二区三区在线看 | 欧美一区二区不卡视频 | 欧美大片一级片 | 国产免费一区二区三区 |