亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

詳解Spring Boot中使用Flyway來管理數據庫版本

2024-07-13 10:15:48
字體:
來源:轉載
供稿:網友

如果沒有讀過上面內容的讀者,有興趣的可以一閱。在上面的使用JdbcTemplate一文中,主要通過spring提供的JdbcTemplate實現對用戶表的增刪改查操作。在實現這個例子的時候,我們事先在MySQL中創建了用戶表。創建表的過程我們在實際開發系統的時候會經常使用,但是一直有一個問題存在,由于一個系統的程序版本通過git得到了很好的版本控制,而數據庫結構并沒有,即使我們通過Git進行了語句的版本化,那么在各個環境的數據庫中如何做好版本管理呢?下面我們就通過本文來學習一下在Spring Boot中如何使用Flyway來管理數據庫的版本。

Flyway簡介

Flyway是一個簡單開源數據庫版本控制器(約定大于配置),主要提供migrate、clean、info、validate、baseline、repair等命令。它支持SQL(PL/SQL、T-SQL)方式和Java方式,支持命令行客戶端等,還提供一系列的插件支持(Maven、Gradle、SBT、ANT等)。

官方網站:https://flywaydb.org/

本文對于Flyway的自身功能不做過多的介紹,讀者可以通過閱讀官方文檔或利用搜索引擎獲得更多資料。下面我們具體說說在Spring Boot應用中的應用,如何使用Flyway來創建數據庫以及結構不一致的檢查。

動手試一試

下面我們可以通過對使用JdbcTemplate一文中的例子進行加工完成。讀者也可以拿任何一個與數據訪問相關的工程來做如下內容的實驗:

第一步,在pom.xml中增加flyway的依賴:

<dependency> <groupId>org.flywaydb</groupId> <artifactId>flyway-core</artifactId> <version>5.0.3</version></dependency>

第二步,按Flyway的規范創建版本化的SQL腳本

在工程的src/main/resources目錄下創建db目錄

在db目錄下創建版本化的SQL腳本V1__Base_version.sql

DROP TABLE IF EXISTS user ;CREATE TABLE `user` ( `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主鍵', `name` varchar(20) NOT NULL COMMENT '姓名', `age` int(5) DEFAULT NULL COMMENT '年齡', PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

第三步,在application.properties文件中配置Flyway要加載的SQL腳本位置。按第二步創建的結果配置如下:

flyway.locations=classpath:/db

第四步,執行單元測試ApplicationTests,此時我們在日志中可以看到如下信息:

INFO 82441 --- [main] o.f.core.internal.util.VersionPrinter  : Flyway Community Edition 5.0.3 by BoxfuseINFO 82441 --- [main] o.f.c.internal.database.DatabaseFactory : Database: jdbc:mysql://localhost:3306/test (MySQL 5.7)INFO 82441 --- [main] o.f.core.internal.command.DbValidate   : Successfully validated 1 migration (execution time 00:00.022s)INFO 82441 --- [main] o.f.c.i.s.JdbcTableSchemaHistory     : Creating Schema History table: `test`.`flyway_schema_history`INFO 82441 --- [main] o.f.core.internal.command.DbMigrate   : Current version of schema `test`: << Empty Schema >>INFO 82441 --- [main] o.f.core.internal.command.DbMigrate   : Migrating schema `test` to version 1 - Base versionWARN 82441 --- [main] o.f.core.internal.sqlscript.SqlScript  : DB: Unknown table 'test.user' (SQL State: 42S02 - Error Code: 1051)INFO 82441 --- [main] o.f.core.internal.command.DbMigrate   : Successfully applied 1 migration to schema `test` (execution time 00:00.128s)

Flyway監測到需要運行版本腳本來初始化數據庫,因此執行了V1__Base_version.sql腳本,從而創建了user表,這才得以讓一系列單元測試(對user表的CRUD操作)通過。

第五步,我們可以繼續再執行一下單元測試,此時我們會發現日志輸出與之前不同:

INFO 83150 --- [main] o.f.core.internal.util.VersionPrinter  : Flyway Community Edition 5.0.3 by BoxfuseINFO 83150 --- [main] o.f.c.internal.database.DatabaseFactory : Database: jdbc:mysql://localhost:3306/test (MySQL 5.7)INFO 83150 --- [main] o.f.core.internal.command.DbValidate   : Successfully validated 1 migration (execution time 00:00.031s)INFO 83150 --- [main] o.f.core.internal.command.DbMigrate   : Current version of schema `test`: 1INFO 83150 --- [main] o.f.core.internal.command.DbMigrate   : Schema `test` is up to date. No migration necessary.

由于在第四步的時候,初始化腳本已經執行過,所以這次執行就沒有再去執行V1__Base_version.sql腳本來重建user表。

第六步,我們可以嘗試修改一下V1__Base_version.sql腳本中的name字段長度,然后在運行一下單元測試,此時我們可以得到如下錯誤:

ERROR 83791 --- [main] o.s.boot.SpringApplication        : Application startup failedorg.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flywayInitializer' defined in class path resource [org/springframework/boot/autoconfigure/flyway/FlywayAutoConfiguration$FlywayConfiguration.class]: Invocation of init method failed; nested exception is org.flywaydb.core.api.FlywayException: Validate failed: Migration checksum mismatch for migration version 1-> Applied to database : 466264992-> Resolved locally  : -270269434

由于初始化腳本的改動,Flyway校驗失敗,認為當前的V1__Base_version.sql腳本與上一次執行的內容不同,提示報錯并終止程序,以免造成更嚴重的數據結構破壞。

總結

到這里為止,本文的內容告一段落。由于博文篇幅問題,對于Flyway更細節的使用沒有說的太多,本文主要作為敲門磚,幫助和引導正在使用Spring Boot做系統開發的個人或團隊在數據庫的版本控制上做的更好提供一些思路。至于更深入的應用還請讀者自行翻閱官方文檔參考和學習。

本文代碼:Github:https://github.com/dyc87112/SpringBoot-Learning/

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
xxx一区二区| 国产精品日日做人人爱| 国产亚洲成av人片在线观看桃| 亚洲精品一区二区久| 在线精品高清中文字幕| 亚洲一区二区久久久久久久| 成人国产精品久久久久久亚洲| 日韩在线免费视频| 自拍偷拍亚洲精品| 不用播放器成人网| 日韩免费看的电影电视剧大全| 久久国产精品视频| 国产精品爽爽爽爽爽爽在线观看| 日韩精品视频免费专区在线播放| 欧美裸体xxxx极品少妇| 日韩在线观看免费全集电视剧网站| 日韩有码片在线观看| 欧美激情小视频| 日韩国产在线看| 亚洲国产精品美女| 在线视频日本亚洲性| 国产日韩欧美在线| 亚洲精品免费网站| 欧美激情喷水视频| 日韩一区视频在线| 91wwwcom在线观看| 精品久久久久久| 55夜色66夜色国产精品视频| 国产精品最新在线观看| 国产精品三级网站| 久久精品电影一区二区| 久久久www成人免费精品张筱雨| 欧美精品videosex牲欧美| 社区色欧美激情 | 欧美日韩国产丝袜另类| 国产精品稀缺呦系列在线| 亚洲色图日韩av| 亚洲春色另类小说| 日本高清视频精品| 国产精品视频永久免费播放| 国产精品亚洲一区二区三区| 欧美黑人巨大精品一区二区| 91高潮精品免费porn| 日韩少妇与小伙激情| 欧美黑人视频一区| 最新国产精品拍自在线播放| 久久久人成影片一区二区三区观看| 三级精品视频久久久久| 亚洲欧美制服中文字幕| 欧美一级bbbbb性bbbb喷潮片| 青青草国产精品一区二区| 国模精品视频一区二区| 大桥未久av一区二区三区| 国产免费一区二区三区在线能观看| 久久综合久久88| 亚洲欧美第一页| 国产热re99久久6国产精品| 91免费精品国偷自产在线| 97精品免费视频| 国产精品视频自在线| 欧美日韩xxxxx| 欧美日韩国产一区二区| 久久久精品免费视频| 亚洲成年网站在线观看| 久久久久久久国产精品视频| 精品成人在线视频| 国产精品久久久久免费a∨大胸| 美女久久久久久久| 国产成人精品999| 久久电影一区二区| 亚洲国产精品资源| 欧美亚洲日本网站| 欧美韩国理论所午夜片917电影| 日韩精品免费视频| 亚洲国产精品va在线观看黑人| 欧美激情在线狂野欧美精品| 久久99视频免费| 欧美久久久精品| 国产精品对白刺激| 国产精品电影网| 日韩欧美国产免费播放| 欧美极品少妇与黑人| 日韩精品亚洲元码| 成人a视频在线观看| 成人久久一区二区三区| 亚洲一级黄色片| 欧洲亚洲妇女av| 欧美性高潮床叫视频| 日韩不卡中文字幕| 国产精品揄拍一区二区| 中文字幕精品—区二区| 欧美成年人在线观看| 久色乳综合思思在线视频| 国外成人免费在线播放| 欧美贵妇videos办公室| 日韩中文字幕精品视频| 欧美在线视频网站| 久久中文久久字幕| 国内揄拍国内精品| 国产午夜精品视频免费不卡69堂| 国产丝袜一区二区三区免费视频| 亚洲国产精品电影在线观看| 欧美黑人又粗大| 欧美色xxxx| 欧美成人免费大片| 日韩欧美在线播放| 日本一区二区三区四区视频| 久久久免费观看视频| 日韩精品中文字幕视频在线| 91av视频在线播放| 亚洲国产美女精品久久久久∴| 亚洲国产精品yw在线观看| 亚洲视频在线看| 国产日韩欧美在线| 国产日韩在线看| 国产精品狠色婷| 亚洲午夜未删减在线观看| 国产精品成av人在线视午夜片| 中文字幕久精品免费视频| 久久精品国产亚洲精品| 精品国产乱码久久久久久婷婷| 欧美激情在线播放| 欧美一级视频免费在线观看| 国产成人一区二区| 激情成人在线视频| 国产视频精品免费播放| 日韩av男人的天堂| 欧美激情喷水视频| 国产午夜精品美女视频明星a级| 久久国产精品久久久久| 欧美激情区在线播放| 亚洲精品98久久久久久中文字幕| 国产精品男女猛烈高潮激情| 亚洲欧洲偷拍精品| 在线亚洲男人天堂| 最新的欧美黄色| 午夜精品久久久久久久男人的天堂| 国产999精品视频| 超碰日本道色综合久久综合| 欧美国产视频一区二区| 成人妇女淫片aaaa视频| 亚洲福利影片在线| 日本aⅴ大伊香蕉精品视频| 亚洲2020天天堂在线观看| 欧美人在线视频| 欧美丰满老妇厨房牲生活| 成人黄色生活片| 欧美在线一区二区三区四| 国产精品免费在线免费| 色偷偷偷综合中文字幕;dd| 亚洲无线码在线一区观看| 亚洲成在人线av| 国产精品福利在线观看| 欧美激情第一页xxx| 日韩在线视频二区| 国产精品久久久久免费a∨| 国产精品444| 欧日韩不卡在线视频| 欧美亚洲国产精品| 国产999在线观看| 成人免费视频网| 在线观看不卡av| 91理论片午午论夜理片久久| 亚洲另类图片色|