亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

spring框架集成flyway項目的詳細過程

 更新時間:2021年07月13日 14:23:19   作者:天下沒有收費的bug  
今天通過本文給大家分享spring框架集成flyway項目的詳細過程,由于大多數(shù)都是springboot集成flyway,很少見到spring框架的項目,今天就抽空給大家介紹下spring框架集成flyway項目的方法,一起看看吧

什么是Spring

Spring是一個開源框架,它由Rod Johnson創(chuàng)建。它是為了解決企業(yè)應用開發(fā)的復雜性而創(chuàng)建的。

   Spring使用基本的JavaBean來完成以前只可能由EJB完成的事情。
  然而,Spring的用途不僅限于服務(wù)器端的開發(fā)。從簡單性、可測試性和松耦合的角度而言,任何Java應用都可以從Spring中受益。
   目的:解決企業(yè)應用開發(fā)的復雜性
   功能:使用基本的JavaBean代替EJB,并提供了更多的企業(yè)應用功能
   范圍:任何Java應用
   它是一個容器框架,用來裝javabean(java對象),中間層框架(萬能膠)可以起一個連接作用,比如說把Struts和hibernate粘合在一起運用。簡單來說,Spring是一個輕量級的控制反轉(zhuǎn)(IoC)和面向切面(AOP)的容器框架。

Flyway簡介

Flyway是一個數(shù)據(jù)庫版本化管理工具,通過SQL腳本實現(xiàn)DB Migration自動化升級,支持獨立運行,也可以和構(gòu)建工具或者Spring開發(fā)環(huán)境集成。

最近給公司項目集成flyway,由于我們項目移動端使用的是spring框架,網(wǎng)上看了很多博客,感覺這方面的東西還是很少的,畢竟現(xiàn)在是springboot的天下,大多數(shù)都是springboot集成flyway。但是還是有不少公司遺留有spring框架的項目。這里就自己肝一篇,希望能幫到更多想把flyway添加到spring項目中的人。

由于使用的是spring框架。因此我們選擇低版本的flyway。

flyway各個版本請到這里去找:https://mvnrepository.com/artifact/org.flywaydb/flyway-core
我們的maven使用的是阿里云的倉庫,阿里云倉庫中沒有低版本的依賴,我們我們需要下載jar包。這里下載的是3.0版本的jar包。

下載的包需要拷貝到項目webapp/WEB-INF/lib中(web項目都會有WEB-INF這個文件夾,只需要找到你項目中web文件夾就行,web文件夾,就是文件夾上有個藍點的,具體看下圖的webapp文件夾)

新建資源目錄resources
在其下面建立db/migration(sql文件默認讀取此路徑下的文件夾中的.sql文件)

在pom.xml中添加,如果不添加,resources中的文件就無法打包到war包中。

 <resource>
                <directory>src/main/resources</directory>
                <includes>
                    <include>**/*</include>
                </includes>
    </resource>

添加flyway配置類,更多配置請看源代碼

package com.dt.flyway;


import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.flywaydb.core.Flyway;
import org.flywaydb.core.api.FlywayException;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;


/**
 * @Description: flyway配置類
 * @author: 
 * @Date: 2021/7/12 15:57
 * @Copyright: Xi'an Dian Tong Software Co., Ltd. All Rights Reserved.
 * @Version 1.0
 */
public class DatabaseFlywayMigration {
    protected final static Logger log = LogManager.getLogger("DatabaseFlywayMigration");

    public void migrate() throws NamingException {
        log.info("DatabaseFlywayMigration-->migrate:flyway開始執(zhí)行,準備獲取數(shù)據(jù)源");
        Context context = new InitialContext();
        //獲取tomcat中的數(shù)據(jù)源
        DataSource dataSource = (DataSource) context.lookup("java:comp/env/jdbc/wxi");
        log.info("DatabaseFlywayMigration-->migrate:獲取數(shù)據(jù)源成功,準備執(zhí)行flyway配置");
        Flyway flyway = new Flyway();
        // 設(shè)置sql腳本文件的編碼
        flyway.setEncoding("UTF-8");
        flyway.setOutOfOrder(true);
        flyway.setDataSource(dataSource);
        // 設(shè)置接受flyway進行版本管理的多個數(shù)據(jù)庫
        //flyway.setSchemas("flywaydemo");
        // 設(shè)置存放flyway metadata數(shù)據(jù)的表名
         flyway.setTable("flyway_schema_history");
        // 設(shè)置執(zhí)行migrate操作之前的validation行為
        //flyway.setValidationMode(ValidationMode.ALL);
        // 設(shè)置當validation失敗時的系統(tǒng)行為
        //flyway.setValidationErrorMode(ValidationErrorMode.FAIL);

        // 設(shè)置當validation失敗時的系統(tǒng)行為
        try {
            flyway.setInitOnMigrate(true);
            log.info("DatabaseFlywayMigration-->migrate:配置成功,即將執(zhí)行sql語句");
            flyway.migrate();
            log.info("DatabaseFlywayMigration-->migrate:sql語句執(zhí)行成功,flyway---END");
        } catch (FlywayException e) {
            log.error("DatabaseFlywayMigration-->migrate:執(zhí)行sql語句失敗,請查看日志排查錯誤");
            flyway.repair();
            e.printStackTrace();
        }
    }
}

在spring的xml中注入flyway配置類的bean(每個spring項目都會帶有一個xml文件,用來注冊bean,復制的時候注意項目中DatabaseFlywayMigration所在的路徑)

<!-- flayway -->
<bean id="flywayMigration1" class="com.dt.flyway.DatabaseFlywayMigration" lazy-init="false" init-method="migrate"> </bean>


到這里,移動端整合flyway就完成了。
以后這些sql語句,只需要放到resources/db/migration文件夾下面即可(但是這些sql命名都是不符合flyway的,需要進行名稱的修改)

命名規(guī)則:
此處的SQL語句命名需要遵從一定的規(guī)范,否則運行的時候flyway會報錯。命名規(guī)則主要有兩種:

僅需要被執(zhí)行一次的SQL命名以大寫的”V”開頭,后面跟上”0~9”數(shù)字的組合,數(shù)字之間可以用“.”或者下劃線”“分割開,然后再以兩個下劃線 _ 分割,其后跟文件名稱,最后以.sql結(jié)尾。比如,V20210707__create_user.sql、V20210707__add_user.sql。
可重復運行的SQL,則以大寫的“R”開頭,后面再以兩個下劃線分割,其后跟文件名稱,最后以.sql結(jié)尾。。比如,R__truncate_user_dml.sql。

其中,V開頭的SQL執(zhí)行優(yōu)先級要比R開頭的SQL優(yōu)先級高。

V:固定大寫

20210707.01:20210707是日期,后面用.01代表序號

因為flyway的執(zhí)行是有個順序的,比如你執(zhí)行了V2021__create_user,有執(zhí)行V2020_update_user。就會報錯,原因就是2020<2021。所以我們要保證序號是依次增大。

Flyway 是如何比較兩個 SQL 文件的先后順序呢?它采用 采用左對齊原則, 缺位用 0 代替 。舉幾個例子:

1.0.1.1 比 1.0.1 版本高。
1.0.10 比 1.0.9.4 版本高。
1.0.10 和 1.0.010 版本號一樣高, 每個版本號部分的前導 0 會被忽略。

__:這個是兩個 _
例如:
V2.0.9__upgrade.sql
V2.0.11__upgrade.sql
V2.0.13__upgrade.sql
V2.0.14__upgrade.sql

作者:天下沒有收費的bug出處:https://www.cnblogs.com/LoveBB/本文版權(quán)歸作者和博客園共有,歡迎轉(zhuǎn)載,但未經(jīng)作者同意必須在文章頁面給出原文鏈接,否則保留追究法律責任的權(quán)利。

到此這篇關(guān)于spring集成flyway的文章就介紹到這了,更多相關(guān)spring集成flyway內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java基礎(chǔ)題新手練習(一)

    Java基礎(chǔ)題新手練習(一)

    下面小編就為大家?guī)硪黄狫ava基礎(chǔ)的幾道練習題(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望可以幫到你
    2021-07-07
  • 新手了解java基礎(chǔ)知識(二)

    新手了解java基礎(chǔ)知識(二)

    這篇文章主要介紹了Java基礎(chǔ)知識,本文介紹了Java語言相關(guān)的基礎(chǔ)知識、歷史介紹、主要應用方向等內(nèi)容,需要的朋友可以參考下,希望對你有所幫助
    2021-07-07
  • Spring?Service功能作用詳細講解

    Spring?Service功能作用詳細講解

    service層測試較簡單,目前大多數(shù)測試主要是針對public方法進行的。依據(jù)測試方法劃分,可以分為兩種:基于mock的隔離測試和基于dbunit的普通測試
    2022-12-12
  • SpringBoot中MyBatis-Flex的集成和使用實現(xiàn)

    SpringBoot中MyBatis-Flex的集成和使用實現(xiàn)

    MyBatis-Flex是一個基于MyBatis的數(shù)據(jù)訪問框架,MyBatis-Flex能夠極大地提高我們的開發(fā)效率和開發(fā)體驗,本文主要介紹了SpringBoot中MyBatis-Flex的集成和使用實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • 分別在Groovy和Java中創(chuàng)建并初始化映射的不同分析

    分別在Groovy和Java中創(chuàng)建并初始化映射的不同分析

    這篇文章主要為大家介紹了分別在Groovy和Java中創(chuàng)建并初始化映射的不同分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

    2022-03-03
  • 解析Jmeter脫離Jenkins后Ant集成郵件通知問題

    解析Jmeter脫離Jenkins后Ant集成郵件通知問題

    今天來講下本地的ant構(gòu)建并發(fā)送郵件。配置下來挺順利也挺簡單的,對Jmeter脫離Jenkins后Ant集成郵件通知問題感興趣的朋友跟隨小編一起看看吧
    2021-12-12
  • 使用MyBatis-Plus實現(xiàn)聯(lián)表查詢分頁的示例代碼

    使用MyBatis-Plus實現(xiàn)聯(lián)表查詢分頁的示例代碼

    本文主要講述了如何在SpringBoot項目中使用MyBatis-Plus的分頁插件,通過這個示例,可以學會如何利用MyBatis-Plus進行高效的分頁查詢,感興趣的可以了解一下
    2024-10-10
  • idea maven項目無法識別jar包里的class解決方案

    idea maven項目無法識別jar包里的class解決方案

    這篇文章主要介紹了idea maven項目無法識別jar包里的class解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • springboot之security?FilterSecurityInterceptor的使用要點記錄

    springboot之security?FilterSecurityInterceptor的使用要點記錄

    這篇文章主要介紹了springboot之security?FilterSecurityInterceptor的使用要點記錄,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • java編程abstract類和方法詳解

    java編程abstract類和方法詳解

    這篇文章主要介紹了java編程abstract類和方法詳解,具有一定借鑒價值,需要的朋友可以參考下。
    2017-12-12

最新評論