国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

java開發flyway的方法

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

FlyWay官網: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做下學習筆記。

數據庫版本管理工具

什么是數據庫版本管理?

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

使用flyway

使用環境

#用的是springboot項目,mysql數據庫

導入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>

創建數據庫腳本目錄

在resources資源目錄下創建db/migration目錄。

添加數據庫腳本

#腳本命名規則 V<VERSION>__<NAME>.sql,P<VERSION>__<NAME>.sql。V代表只執行一次,P代表可以執行多次#VERSION代表數據庫腳本版本,NAME代表數據名稱。#這里使用V1_test.sql,腳本內容如下所示。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文件配置

#指定數據庫腳本為UTF-8, flyway的配置有很多,有興趣的小伙伴可以去看下spring.flyway.encoding=utf-8#如果原來的數據庫不為空,則需要設置spring.flyway.baseline-on-migrate=true#設置數據庫起始版本為0,默認為1。如果你寫的sql腳本version小于等于起始版本則不會執行。spring.flyway.baseline-version=0#數據源配置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

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

java開發flyway的方法

數據庫查看

java開發flyway的方法

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

flyway是怎么執行的?

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

到此這篇關于java開發flyway的方法的文章就介紹到這了,更多相關java開發flyway內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 就草草在线观看视频 | 俄罗斯特级毛片 | 美女亚洲视频 | 国产日韩不卡免费精品视频 | 国产精品免费一区二区三区 | 性久久久久久久 | 成人永久免费视频网站在线观看 | 精品免费在线视频 | 久草新免费 | 精品一区二区三区在线成人 | 九九re6精品视频在线观看 | 小明日韩在线看看永久区域 | 欧美一区二区不卡视频 | 波多野结衣中文在线播放 | 成人免费在线视频 | 欧美日韩另类在线观看视频 | 99久热在线精品视频观看 | 一级毛片真人不卡免费播 | 中文无码日韩欧免费视频 | 天天躁夜夜躁狠狠躁2024 | 一级欧美一级日韩毛片99 | 俄罗斯极品美女毛片免费播放 | 欧美亚洲午夜 | 精品免费久久久久国产一区 | 最新国产精品好看的国产精品 | 欧美一区a | 日本欧美国产精品 | 中文字幕无线码中文字幕网站 | 在线欧美精品二区三区 | 黄色免费三级 | 男女视频免费看 | 香蕉久久一区二区不卡无毒影院 | 亚洲欧美日韩高清 | 欧美高清一区二区三 | 欧美在线一区二区三区不卡 | 亚洲精品久久久久中文 | 黄色网址在线免费观看 | 欧美一区二区三区视频 | 美女舒服好紧太爽了视频 | 国产素人在线观看 | 高清一本之道加勒比在线 |