您好,登錄后才能下訂單哦!
這篇文章主要講解了“Flyway怎么部署”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Flyway怎么部署”吧!
我們在公司做開發(fā)時(shí),由于項(xiàng)目需求的變化,或者前期設(shè)計(jì)缺陷,導(dǎo)致在后期需要修改數(shù)據(jù)庫,這應(yīng)該是一個(gè)比較常見的事情,如果項(xiàng)目還沒上線,你可能把表刪除了重新創(chuàng)建,但是如果項(xiàng)目已經(jīng)上線了,就不能這樣簡單粗暴了,我們需要通過 SQL 腳本在已有數(shù)據(jù)表的基礎(chǔ)上進(jìn)行升級。
目前 Java 這塊,想要對數(shù)據(jù)庫的版本進(jìn)行管理主要有兩個(gè)工具:
兩個(gè)工具各有千秋,但是核心功能都是數(shù)據(jù)庫的版本管理,這里主要來看 Flyway。就像我們使用 Git 來管理代碼版本一樣,F(xiàn)lyway 可以用來管理數(shù)據(jù)庫版本。
好了,接下來我們就來看看用 Flyway 如何簡化微人事部署,然后再來說說 Flyway 的一個(gè)大致原理。
如果是在一個(gè)全新的項(xiàng)目中使用 Flyway,那么在新建一個(gè) Spring Boot 項(xiàng)目時(shí),就有 Flyway 的選項(xiàng),如下圖:
項(xiàng)目創(chuàng)建成功后,resources 目錄下也會多出來一個(gè) db/migration 目錄,這個(gè)目錄用來存放數(shù)據(jù)庫腳本,如下:
「注意」
這個(gè)如果創(chuàng)建項(xiàng)目時(shí)就選擇了 Flyway 依賴,就會有這個(gè)目錄?,F(xiàn)在我要在已經(jīng)做好的微人事中加入 Flyway,這個(gè)目錄就需要我手動(dòng)創(chuàng)建了。
首先在微人事中添加 flyway 依賴:
<dependency>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-core</artifactId>
</dependency>
然后在 vhr-web 模塊下的 resources 目錄下,手動(dòng)創(chuàng)建 db/migration 目錄,然后在該目錄下創(chuàng)建數(shù)據(jù)庫腳本,數(shù)據(jù)庫腳本的命名方式如下:
V<VERSION>__<NAME>.sql
首先是大寫字母 V,然后是版本號,要是有小版本可以用下劃線隔開,例如 2_1,版本號后面是兩個(gè)下劃線,然后是腳本名稱,文件后綴是 .sql。
例如我這里創(chuàng)建我的第一個(gè)數(shù)據(jù)庫腳本,取名為 V1__vhr.sql
,腳本內(nèi)容就是微人事的數(shù)據(jù)庫腳本,大家可以在 https://github.com/lenve/vhr 這里獲取到。
完了之后,可以不用添加額外配置,大家只需要在本地 MySQL 中創(chuàng)建一個(gè)空的 vhr 數(shù)據(jù)庫即可,然后直接啟動(dòng)微人事項(xiàng)目,項(xiàng)目啟動(dòng)成功后,我們查看啟動(dòng)日志:
從這段啟動(dòng)日志中,我們可以看到 Flyway 的執(zhí)行信息,數(shù)據(jù)庫腳本的執(zhí)行執(zhí)行,同時(shí)這里還說了,F(xiàn)lyway 還給創(chuàng)建了一個(gè) flyway_schema_history 表,這個(gè)表用來記錄數(shù)據(jù)庫的更新歷史。
這個(gè)時(shí)候,打開本地?cái)?shù)據(jù)庫,我們發(fā)現(xiàn) vhr 庫中該有的表都有了。同時(shí)還發(fā)現(xiàn)了 flyway_schema_history 表,如下:
有了這條記錄,下次再啟動(dòng) vhr 項(xiàng)目,V1__vhr.sql 這個(gè)腳本文件就不會執(zhí)行了,因?yàn)橄到y(tǒng)知道這個(gè)腳本已經(jīng)執(zhí)行過了,如果你還想讓 V1__vhr.sql 腳本再執(zhí)行一遍,需要手動(dòng)刪除 flyway_schema_history 表中的對應(yīng)記錄,那么項(xiàng)目啟動(dòng)時(shí),這個(gè)腳本就會被執(zhí)行了。
在 Spring Boot 中,關(guān)于 Flyway 也有不少配置,這些配置都在 application.properties 中進(jìn)行配置,常用的幾個(gè)來和大家說下:
感謝各位的閱讀,以上就是“Flyway怎么部署”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對Flyway怎么部署這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。