資料庫版本管理工具 什麼是資料庫版本管理? 做過開發的小伙伴們都知道,實現一個需求時,一般情況下都需要設計到資料庫表結構的修改。那麼我們怎麼能保證項目多人開發時,多個資料庫環境(測試,生產環境)能夠保持一致呢?在沒有資料庫版本管理工具之前,需要將資料庫修改腳本拷貝到每個資料庫環境進行執行。而有了數據 ...
資料庫版本管理工具
什麼是資料庫版本管理?
做過開發的小伙伴們都知道,實現一個需求時,一般情況下都需要設計到資料庫表結構的修改。那麼我們怎麼能保證項目多人開發時,多個資料庫環境(測試,生產環境)能夠保持一致呢?在沒有資料庫版本管理工具之前,需要將資料庫修改腳本拷貝到每個資料庫環境進行執行。而有了資料庫版本管理工具之後,程式在啟動的時候就會根據實現定義好的規則來進行資料庫腳本的執行。
使用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=false
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.username=root
spring.datasource.password=123456
啟動應用程式,查看控制台輸出
資料庫查看
此時flyway會預設添加一張記錄資料庫版本信息的表,每次啟動時會根據version值判斷是否需要執行sql。
flyway是怎麼執行的?
#spring-boot-dependencies 導入了flyway,mysql依賴。
#spring-boot-autoconfigure 中導入了FlywayAutoConfiguration自動配置類