sql脚本对比工具_Java开发中用到的数据库迁移工具(flyway)
生活随笔
收集整理的這篇文章主要介紹了
sql脚本对比工具_Java开发中用到的数据库迁移工具(flyway)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
什么是數據庫版本管理?
任何web軟件和應用程序都需要強大的數據庫管理工具,因此開發者選擇一款合適的數據庫管理工具尤為重要。本文列出了幾款好用的數據庫管理工具(有些并非開源或免費),以供開發者們參考選擇,做過開發的小伙伴們都知道,實現一個需求時,一般情況下都需要設計到數據庫表結構的修改。那么我們怎么能保證項目多人開發時,多個數據庫環境(測試,生產環境)能夠保持一致呢?在沒有數據庫版本管理工具之前,需要將數據庫修改腳本拷貝到每個數據庫環境進行執行。而有了數據庫版本管理工具之后,程序在啟動的時候就會根據實現定義好的規則來進行數據庫腳本的執行。
使用flyway
使用環境
#我自己用的是springboot項目,mysql數據庫
導入flayway和mysql依賴
org.flywaydb flyway-coremysql mysql-connector-javaorg.springframework.boot spring-boot-starter-jdbc創建數據庫腳本目錄
在resources資源目錄下創建db/migration目錄。添加數據庫腳本
#腳本命名規則 V__.sql,P__.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啟動應用程序,查看控制臺輸出
數據庫查看
此時flyway會默認添加一張記錄數據庫版本信息的表,每次啟動時會根據version值判斷是否需要執行sql。
flyway是怎么執行的?
#spring-boot-dependencies 導入了flyway,mysql依賴。#spring-boot-autoconfigure 中導入了FlywayAutoConfiguration自動配置類總結
以上是生活随笔為你收集整理的sql脚本对比工具_Java开发中用到的数据库迁移工具(flyway)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: iPhone iPad 各种控件默认高度
- 下一篇: mysql查看binlog日志内容