亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

java開發(fā)flyway的方法

瀏覽:8日期:2022-08-28 11:23:26

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中排第一位的搜索結(jié)果就是flyway,那就之后有機會再與其它方案做比較,先對flyway做下學(xué)習(xí)筆記。

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

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

做過開發(fā)的小伙伴們都知道,實現(xiàn)一個需求時,一般情況下都需要設(shè)計到數(shù)據(jù)庫表結(jié)構(gòu)的修改。那么我們怎么能保證項目多人開發(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ù)庫

導(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=falsespring.datasource.driver-class-name=com.mysql.jdbc.Driverspring.datasource.username=rootspring.datasource.password=123456

啟動應(yīng)用程序,查看控制臺輸出

java開發(fā)flyway的方法

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

java開發(fā)flyway的方法

此時flyway會默認(rèn)添加一張記錄數(shù)據(jù)庫版本信息的表,每次啟動時會根據(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)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 国产成人精品cao在线 | 黄黄的网站在线观看 | 黄色网页在线观看 | 久久精品2021国产 | 国产精品大全 | 欧美一级毛片免费看视频 | 国产欧美在线观看 | 中文字幕亚洲欧美一区 | 国内小情侣一二三区在线视频 | 久久优| 狠狠色丁香久久综合婷婷 | 欧美一级久久久久久久大片 | 2021国产麻豆剧传媒精品网站 | 99久久国产综合精品2020 | 日批日韩在线观看 | 怡红院男人天堂 | 超乳w真性中出し冲田杏梨101 | 精品综合久久久久久97超人该 | 99久久综合国产精品免费 | 久久精品2021国产 | 51精品视频免费国产专区 | 国产精品大白天新婚身材 | 一级做a爰片久久毛片看看 一级做a爰片久久毛片美女 | 国产不卡在线观看 | www亚洲视频| 国内精品91 | 成人资源网站 | 欧美日韩视频在线 | 成人亲子乱子伦视频 | 亚洲欧美日韩国产一区二区精品 | 国产欧美日韩中文久久 | 国产精品吹潮在线播放 | 丁香综合网 | 手机看片国产欧美日韩高清 | 国产精品午夜高清在线观看 | 国产乱码亚洲精品一区二区 | 亚洲国产精品一区二区三区在线观看 | 91免费在线视频 | 中文字幕免费在线观看动作大片 | 高清在线一区二区三区亚洲综合 | 国产亚洲精品成人久久网站 |