国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - SpringBoot使用Flyway進行數據庫管理的操作方法

SpringBoot使用Flyway進行數據庫管理的操作方法

2022-01-07 12:58懶蟲蟲~ Java教程

Flyway是一個開源的數據庫版本管理工具,并且極力主張“約定大于配置”,簡單、專注、強大。接下來通過本文給大家介紹SpringBoot使用Flyway進行數據庫管理的方法,感興趣的朋友一起看看吧

 

一、Flyway簡介

Flyway是一款數據庫遷移(migration)工具。簡單點說,就是在你部署應用的時候,幫你執行數據庫腳本的工具。Flyway支持SQL和Java兩種類型的腳本,你可以將腳本打包到應用程序中,在應用程序啟動時,由Flyway來管理這些腳本的執行,這些腳本被Flyway稱之為migration。

就目前而言,我們部署應用的流程大概是這樣的:

開發人員將應用程序打包、按順序匯總并整理數據庫升級腳本
DBA拿到數據庫升級腳本檢查、備份、執行,以完成數據庫升級
應部署人員拿到應用部署包,備份、替換,以完成應用程序升級
引入Flyway之后的應用部署流程大概是這樣的:

開發人員將應用程序打包
應部署人員拿到應用部署包,備份、替換,以完成應用程序升(Flyway將自動執行升級/備份腳本)。

 

二、SpringBoot集成使用

 

1.pom.xml引入依賴

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.0.3.RELEASE</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>
	<groupId>com.example</groupId>
	<artifactId>demo</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<name>demo</name>
	<description>Demo project for Spring Boot</description>
	<properties>
		<java.version>1.8</java.version>
	</properties>
	<dependencies>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter</artifactId>
		</dependency>

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
		</dependency>

		<!-- mysql 依賴 -->
		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
		</dependency>

		<!-- 數據庫版本管理 依賴 -->
		<dependency>
			<groupId>org.flywaydb</groupId>
			<artifactId>flyway-core</artifactId>
		</dependency>

		<!-- 數據庫訪問依賴 -->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-jdbc</artifactId>
		</dependency>

		<!-- 自動生成get,set方法 依賴 -->
		<dependency>
			<groupId>org.projectlombok</groupId>
			<artifactId>lombok</artifactId>
		</dependency>

	</dependencies>

	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>

</project>

 

2.application.properties

# 端口
server.port=8082

# 數據源
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/test1?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true&serverTimezone=PRC&useSSL=false
spring.datasource.username=root
spring.datasource.password=root

# flyway    注:可以完全不用配置
## sql 腳本的位置,默認為 classpath:db/migration。可手動指定
spring.flyway.locations=classpath:db
##  指定數據源,如果沒有指定的話,將使用配置的主數據源
spring.flyway.url=jdbc:mysql://127.0.0.1:3306/test1?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true&serverTimezone=PRC&useSSL=false
## Flyway 管理的 Schema 列表,區分大小寫。默認連接對應的默認 Schema
## 如果這里明確指定了庫名,那么在 spring.flyway.url 連接中指定的庫名將無效
spring.flyway.schemas=test1
## 用戶名
spring.flyway.user=root
## 密碼
spring.flyway.password=root
## 開啟,默認開啟
spring.flyway.enabled=true

 

3.resources創建db數據庫腳本文件夾

V0.1.0__init_table.sql

-- 創建表
create table t_startAlarm
(
    id      int(100) primary key not null auto_increment,
    name     varchar(100),
    type      varchar(100)
)

V0.1.1__init_table.sql

-- 初始化數據
INSERT INTO t_startAlarm ( id , name , type ) VALUES
("1","電飯煲","用來蒸飯")

V0.1.2__init_table.sql

-- 初始化數據
INSERT INTO t_startAlarm ( id , name , type ) VALUES
("2","電飯煲2","用來蒸飯2")

 

4.啟動DemoApplication主啟動類

4.1只有V0.1.0__init_table.sql和V0.1.1__init_table.sql。
項目啟動,Flyway 會自動創建一個 flyway_schema_history 表,這個表用來記錄數據庫的更新歷史。

有了這條記錄,下次再啟動項目,V0.1.1__init_table.sql 這個腳本文件就不會執行了,因為系統知道這個腳本已經執行過了,如果你還想讓 V0.1.1__init_table.sql 腳本再執行一遍,需要手動刪除 flyway_schema_history 表中的對應記錄,那么項目啟動時,這個腳本就會被執行了。

注意:

我們在定義腳本的時候,除了 V 字開頭的腳本之外,還有一種 R 字開頭的腳本,V 字開頭的腳本只會執行一次,而 R字開頭的腳本,只要腳本內容發生了變化,啟動時候就會執行。

使用了 Flyway之后,如果再想進行數據庫版本升級,就不用該以前的數據庫腳本了,直接創建新的數據庫腳本,項目在啟動時檢測了有新的更高版本的腳本,就會自動執行,這樣,在和其他同事配合工作時,也會方便很多。因為正常我們都是從Git 上拉代碼下來,不拉數據庫腳本,這樣要是有人更新了數據庫,其他同事不一定能夠收到最新的通知,使用了 Flyway就可以有效避免這個問題了。

所有的腳本,一旦執行了,就會在 flyway_schema_history表中有記錄,如果你不小心搞錯了,可以手動從 flyway_schema_history 表中刪除記錄,然后修改 SQL腳本后再重新啟動(生產環境不建議)。

測試數據庫中結果:

SpringBoot使用Flyway進行數據庫管理的操作方法
SpringBoot使用Flyway進行數據庫管理的操作方法

添加V0.1.2__init_table.sql,測試數據庫中結果

SpringBoot使用Flyway進行數據庫管理的操作方法

SpringBoot使用Flyway進行數據庫管理的操作方法

 

三、項目整體結構

代碼地址鏈接: SpringbootFlyway

SpringBoot使用Flyway進行數據庫管理的操作方法

參考文章

https://www.cnblogs.com/wangzh1guo/articles/13834706.html

到此這篇關于SpringBoot使用Flyway進行數據庫管理的文章就介紹到這了,更多相關SpringBoot Flyway數據庫管理內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/jike11231/article/details/120343725

延伸 · 閱讀

精彩推薦
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
主站蜘蛛池模板: 一区二区三区免费观看视频 | av色伊人久久综合一区二区 | 精品黄色国产 | 99在线精品视频 | 伊人五月天在线 | 成人在线激情网 | 欧美日韩第一页 | 超碰91在线 | av看片网| 亚洲成人精品在线 | 九九在线精品视频 | 中文在线一区二区三区 | 色之久久综合 | 永久免费在线 | 综合久久综合 | 亚洲高清毛片一区二区 | 综合网视频 | 91精品国产一区二区 | 亚洲激情视频在线播放 | 成人精品一区二区 | 国产精品久久久久久吹潮 | 久久久久在线 | 午夜视频网 | 久草在线视频免费播放 | 亚洲一区二区高清 | 黄色一级片免费 | 亚洲国产精品久久久 | 久久精品国产99 | 欧美精品偷拍 | 日韩欧美在线一区 | 精品香蕉一区二区三区 | 国产福利在线观看 | 国产精品一区二区三区不卡 | 欧美a级成人淫片免费看 | 日韩在线精品视频 | 视频网站免费观看 | 激情网婷婷 | 日韩免费 | 久久综合久色欧美综合狠狠 | 国产资源在线观看 | 日韩精品免费在线视频 |