日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

flyway常用配置_Spring Boot 2.x基础教程:使用Flyway管理数据库版本

發(fā)布時(shí)間:2025/3/15 javascript 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 flyway常用配置_Spring Boot 2.x基础教程:使用Flyway管理数据库版本 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

之前已經(jīng)介紹了很多在Spring Boot中使用MySQL的案例,包含了Spring Boot最原始的JdbcTemplate、Spring Data JPA以及我們國內(nèi)最常用的MyBatis。同時(shí),對于一些復(fù)雜場景比如:更換Druid數(shù)據(jù)源,或是多數(shù)據(jù)源的情況也都做了介紹。

不論我們使用哪一個(gè)具體實(shí)現(xiàn)框架,都離不開對數(shù)據(jù)庫表結(jié)構(gòu)的管理。而這一類管理一直都存在一個(gè)問題:由于數(shù)據(jù)庫表元數(shù)據(jù)存儲(chǔ)于數(shù)據(jù)庫中,而我們的訪問邏輯都存在于Git或其他代碼倉庫中。Git已經(jīng)幫助我們完成了代碼的多版本管理,那么數(shù)據(jù)庫中的表該如何做好版本控制呢?

今天我們就來介紹在Spring Boot中使用Flyway來管理數(shù)據(jù)庫版本的方法。

Flyway簡介

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

官方網(wǎng)站:https://flywaydb.org/

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

動(dòng)手試試

下面我們先預(yù)設(shè)一個(gè)開發(fā)目標(biāo):

假設(shè)我們需要開發(fā)一個(gè)用戶管理系統(tǒng),那么我們勢必要設(shè)計(jì)一張用戶表,并實(shí)現(xiàn)對用戶表的增刪改查操作。

在任務(wù)1的功能完成之后,我們又有一個(gè)新需求,需要對用戶表增加了一個(gè)字段,看看如何實(shí)現(xiàn)對數(shù)據(jù)庫表結(jié)構(gòu)的更改。

目標(biāo) 1 的實(shí)現(xiàn)

第一步:創(chuàng)建一個(gè)基礎(chǔ)的Spring Boot項(xiàng)目,并在pom.中加入Flyway、MySQL連接和數(shù)據(jù)訪問相關(guān)的必要依賴(這里選用spring-boot-starter-jdbc作為例子)

org.springframework.bootspring-boot-starter-weborg.springframework.bootspring-boot-starter-jdbcmysqlmysql-connector-javaorg.flywaydbflyway-coreorg.projectlomboklombokprovidedorg.springframework.bootspring-boot-starter-testtest

第二步:按Flyway的規(guī)范創(chuàng)建版本化的SQL腳本。

在工程的src/main/resources目錄下創(chuàng)建db目錄,在db目錄下再創(chuàng)建migration目錄

在migration目錄下創(chuàng)建版本化的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;

注意:如果你不想將SQL腳本放到其他目錄,可以用spring.flyway.locations參數(shù)來配置。這里不同于1.x版本的配置項(xiàng)flyway.locations

第三步:根據(jù)User表的結(jié)構(gòu),編寫對應(yīng)的實(shí)體定義

@Data@NoArgsConstructorpublic class User { private Long id; private String name; private Integer age;}

第四步:編寫用戶操作接口和實(shí)現(xiàn)

public interface UserService { /** * 新增一個(gè)用戶 * * @param name * @param age */ int create(String name, Integer age); /** * 根據(jù)name查詢用戶 * * @param name * @return */ List getByName(String name); /** * 根據(jù)name刪除用戶 * * @param name */ int deleteByName(String name); /** * 獲取用戶總量 */ int getAllUsers(); /** * 刪除所有用戶 */ int deleteAllUsers();}@Servicepublic class UserServiceImpl implements UserService { private JdbcTemplate jdbcTemplate; UserServiceImpl(JdbcTemplate jdbcTemplate) { this.jdbcTemplate = jdbcTemplate; } @Override public int create(String name, Integer age) { return jdbcTemplate.update("insert into USER(NAME, AGE) values(?, ?)", name, age); } @Override public List getByName(String name) { List users = jdbcTemplate.query("select * from USER where NAME = ?", (resultSet, i) -> { User user = new User(); user.setId(resultSet.getLong("ID")); user.setName(resultSet.getString("NAME")); user.setAge(resultSet.getInt("AGE")); return user; }, name); return users; } @Override public int deleteByName(String name) { return jdbcTemplate.update("delete from USER where NAME = ?", name); } @Override public int getAllUsers() { return jdbcTemplate.queryForObject("select count(1) from USER", Integer.class); } @Override .........

總結(jié)

以上是生活随笔為你收集整理的flyway常用配置_Spring Boot 2.x基础教程:使用Flyway管理数据库版本的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 久久泄欲网 | 妹子色综合 | 午夜伦理福利视频 | 亚洲综合一 | jizz中国女人高潮 | 日韩一本在线 | 日本三级中国三级99人妇网站 | 永久免费看成人av的动态图 | 久久精品天堂 | 成年人免费视频网站 | 美女免费毛片 | 日韩电影中文字幕在线观看 | 日本国产一区二区 | 精品视频无码一区二区三区 | 国产精品亚洲一区 | 日本黄色动态图 | av中文网 | 精品日韩视频 | 亚洲av永久无码精品三区在线 | www.色日本| 色综合一区二区 | 欧美一二区| 男女啪啪十八 | 在线观看亚洲欧美 | 九九热在线免费视频 | 乱xxxxx普通话对白 | 午夜寂寞影院在线观看 | 九色福利| 国产第五页 | 欧美成人精品三级网站 | av大全在线播放 | 日本成人午夜视频 | mm131丰满少妇人体欣赏图 | 丁香激情五月少妇 | 公交顶臀绿裙妇女配视频 | 国产乱真实合集 | 久久久久亚洲av无码专区桃色 | 国产超级av| 精品人妻伦一二三区久久 | 国产av成人一区二区三区 | 欧美日韩三 | 中文字幕一区二区三区四区 | 椎名空在线 | 日韩在线视频免费 | 精品麻豆视频 | 亚洲午夜精品久久久久久app | 最新在线观看av | 精品婷婷色一区二区三区蜜桃 | 麻豆影音先锋 | 亚洲视频在线观看一区 | 毛片av在线 | 日韩黄色片在线观看 | 成人性视频在线 | 99re视频在线观看 | 久久精品免费一区二区 | 色婷婷狠狠干 | jizzjizz在线观看 | 四色永久访问 | 亚洲激情网站 | 久久免费视频99 | 国产美女作爱全过程免费视频 | 91精品国产高清91久久久久久 | 国产成人免费在线观看 | 国产欧美日韩在线视频 | 国产女主播喷水高潮网红在线 | 日韩一级色| 欧美性猛交xxxx免费看久久久 | 裸体毛片 | 欧美午夜不卡 | 男人综合网| 欧美精品乱码视频一二专区 | 欧美三级午夜理伦 | 欧美第十页 | 国产精品啊啊啊 | 九九免费在线视频 | 国产妻精品一区二区在线 | 一二三区不卡 | 欧美综合自拍 | 欧美性猛交 xxxx| 97久久久久久 | 久久免费国产 | 中文字幕免费播放 | 三级在线视频 | 久久精品国产亚洲AV熟女 | 色一情一乱一伦一区二区三区 | 色哟哟精品一区 | 男女激情大尺度做爰视频 | 日本bbwbbw| 午夜在线免费视频 | 国产精品久久伊人 | 女性女同性aⅴ免费观女性恋 | 欧美1区2区 | 欧美日韩aaa | 久久精品视频2 | 国产精品 日韩 | 国产专区欧美专区 | 久草三级 | 高级毛片 | 六月婷婷激情网 |