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

springboot下配置多數(shù)據(jù)源的方法

 更新時(shí)間:2017年04月19日 10:21:51   作者:十丿四  
本篇文章主要介紹了springboot下配置多數(shù)據(jù)源的方法,具有一定的參考價(jià)值,有興趣的可以了解一下

一、springboot 簡(jiǎn)介

SpringBoot使開(kāi)發(fā)獨(dú)立的,產(chǎn)品級(jí)別的基于Spring的應(yīng)用變得非常簡(jiǎn)單,你只需"just run"。 我們?yōu)镾pring平臺(tái)及第三方庫(kù)提 供開(kāi)箱即用的設(shè)置,這樣你就可以有條不紊地開(kāi)始。多數(shù)Spring Boot應(yīng)用需要很少的Spring配置。

你可以使用SpringBoot創(chuàng)建Java應(yīng)用,并使用 java -jar 啟動(dòng)它或采用傳統(tǒng)的war部署方式。我們也提供了一個(gè)運(yùn)行"spring 腳本"的命令行工具。

二、傳統(tǒng)的DataSource配置

Java的javax.sql.DataSource接口提供了一個(gè)標(biāo)準(zhǔn)的使用數(shù)據(jù)庫(kù)連接的方法。傳統(tǒng)做法是,一個(gè)DataSource使用一個(gè)URL連

同相應(yīng)的證書(shū)去初始化一個(gè)數(shù)據(jù)庫(kù)連接。

開(kāi)發(fā)中,一個(gè)項(xiàng)目中經(jīng)常會(huì)使用到不知一個(gè)數(shù)據(jù)源,本文主要講解如何在springboot下整合mybatis配置多數(shù)據(jù)源。主要對(duì)比下傳統(tǒng)的xml配置數(shù)據(jù)源和springboot下的數(shù)據(jù)源配置。

首先介紹下傳統(tǒng)的xml下如何配置多數(shù)據(jù)源

1、項(xiàng)目結(jié)構(gòu)

使用maven構(gòu)建的項(xiàng)目中,所有的數(shù)據(jù)源配置到DAO層,即圖中 subscribecore.dal module

2、dal的目錄結(jié)構(gòu)

1、數(shù)據(jù)庫(kù)對(duì)應(yīng)的java實(shí)體類。

2、每個(gè)庫(kù)對(duì)應(yīng)的mapper文件。

3、每個(gè)mapper文件對(duì)應(yīng)的到的xml文件。

4、生產(chǎn)環(huán)境\測(cè)試環(huán)境對(duì)應(yīng)的數(shù)據(jù)源配置文件。

5、每個(gè)數(shù)據(jù)庫(kù)對(duì)應(yīng)的配置文件。

3、具體的配置文件介紹

以mysql庫(kù)為例,詳細(xì)展開(kāi)對(duì)mysql數(shù)據(jù)配置的介紹

1、java實(shí)體類

使用的mysql庫(kù)中的一張表,通過(guò)mybatis自動(dòng)生成工具,生成了chartconfig類和chartconfigExample類。

2、msyql庫(kù)的mapper文件

3、mapper文件對(duì)應(yīng)的到的xml文件

4、mysql測(cè)試環(huán)境對(duì)應(yīng)的數(shù)據(jù)源配置文件

5、myssql數(shù)據(jù)庫(kù)對(duì)應(yīng)的配置文件

<?xml version="1.0" encoding="UTF-8"?> 
<beans xmlns="http://www.springframework.org/schema/beans" 
    xmlns:context="http://www.springframework.org/schema/context" 
    xmlns:tx="http://www.springframework.org/schema/tx" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:aop="http://www.springframework.org/schema/aop" xmlns:cache="http://www.springframework.org/schema/cache" 
    xsi:schemaLocation="http://www.springframework.org/schema/beans   http://www.springframework.org/schema/beans/spring-beans.xsd 
            http://www.springframework.org/schema/context  http://www.springframework.org/schema/context/spring-context.xsd 
            http://www.springframework.org/schema/tx   http://www.springframework.org/schema/tx/spring-tx.xsd 
            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd 
            http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache.xsd"> 
  <context:component-scan base-package="com.zto.subscribecore"></context:component-scan> 
 
 
 
  <!-- 數(shù)據(jù)源 --> 
  <bean id="mysqlDataSource" class="com.alibaba.druid.pool.DruidDataSource" 
     init-method="init" destroy-method="close"> 
    <!-- 驅(qū)動(dòng)名稱 --> 
    <property name="DriverClassName" value="${mysql.DriverClassName}"/> 
    <!-- JDBC連接串 --> 
    <property name="url" value="${mysql.url}"/> 
    <!-- 數(shù)據(jù)庫(kù)用戶名稱 --> 
    <property name="username" value="${mysql.username}"/> 
    <!-- 數(shù)據(jù)庫(kù)密碼 --> 
    <property name="password" value="${mysql.password}"/> 
    <!-- 連接池最大使用連接數(shù)量 --> 
    <property name="maxActive" value="${mysql.maxActive}"/> 
    <!-- 初始化大小 --> 
    <property name="initialSize" value="${mysql.initialSize}"/> 
    <!-- 獲取連接最大等待時(shí)間 --> 
    <property name="maxWait" value="${mysql.maxWait}"/> 
    <!-- 連接池最小空閑 --> 
    <property name="minIdle" value="${mysql.minIdle}"/> 
    <!-- 逐出連接的檢測(cè)時(shí)間間隔 --> 
    <property name="timeBetweenEvictionRunsMillis" value="${mysql.timeBetweenEvictionRunsMillis}"/> 
    <!-- 最小逐出時(shí)間 --> 
    <property name="minEvictableIdleTimeMillis" value="${mysql.minEvictableIdleTimeMillis}"/> 
    <!-- 測(cè)試有效用的SQL Query --> 
    <property name="validationQuery" value="${mysql.validationQuery}"/> 
    <!-- 連接空閑時(shí)測(cè)試是否有效 --> 
    <property name="testWhileIdle" value="${mysql.testWhileIdle}"/> 
    <!-- 獲取連接時(shí)測(cè)試是否有效 --> 
    <property name="testOnBorrow" value="${mysql.testOnBorrow}"/> 
    <!-- 歸還連接時(shí)是否測(cè)試有效 --> 
    <property name="testOnReturn" value="${mysql.testOnReturn}"/> 
  </bean> 
 
  <bean id="mysqlTransactionManager" 
     class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> 
    <property name="dataSource" ref="mysqlDataSource"/> 
  </bean> 
 
  <tx:annotation-driven transaction-manager="mysqlTransactionManager"/> 
 
  <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> 
    <property name="basePackage" value="com.zto.subscribecore.dal.mapper.mysql"/> 
    <property name="sqlSessionFactoryBeanName" value="mysqlSqlSessionFactory"/> 
  </bean> 
 
  <bean id="mysqlSqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> 
    <property name="dataSource" ref="mysqlDataSource"/> 
    <property name="mapperLocations" value="classpath*:com/zto/subscribecore/dal/mapper/mysql/*.xml"></property> 
    <property name="typeAliasesPackage" value="com.zto.subscribecore.dal.domain"/> 
  </bean> 
 
</beans> 

配制文件步驟分解:

1、注入數(shù)據(jù)源,即 bean id為mysqlDatasource的配置文件,該配置可以從jdbc-dev.properties文件中讀取到對(duì)應(yīng)到數(shù)據(jù)庫(kù)配置文件。

2、聲明DataSourceTransactionManager 即 bean id為 mysqlTransactionManager 的配置文件,該配置 為事務(wù)管理,在spring中是對(duì)JdbcTemplate進(jìn)行事務(wù)管理

3、自動(dòng)掃描包,即 bean class 為 org.mybatis.spring.mapper.MapperScannerConfigurer的配置文件。該配置 將mapper接口生成的代理注入到spring。可以自動(dòng)掃描該包名下的所有的文件,即 實(shí)體類,mapper接口類,和mapper接口對(duì)應(yīng)的xml文件。

4、創(chuàng)建seesion,即bean id為 mysqlSqlSessionFactory 的配置文件,該配置中指定了對(duì)應(yīng)mysql庫(kù)的xml文件和對(duì)應(yīng)的實(shí)體類的路徑。一個(gè)sqlSeesionFactory代表了一個(gè)數(shù)據(jù)源。(就相當(dāng)于產(chǎn)生連接池)

至此完成了mysql庫(kù)的配置。

三、springboot下的datasource配置

通過(guò)上面的配置文件,了解到數(shù)據(jù)源的相關(guān)配置,下面描述下如何在springboot下完成多數(shù)據(jù)源的配置工作。

1、目錄結(jié)構(gòu)

同樣,使用maven構(gòu)建多module的工程,但是取消了jdbc-properties,數(shù)據(jù)連接配置卸載寫(xiě)在application.yml中。dao層的文件

配置的dal module中。

application.yml的內(nèi)容:

1、注入數(shù)據(jù)源,使用@Configuration注解,springboot在啟動(dòng)時(shí),會(huì)自動(dòng)加載該類,和xml聲明類似。(同 <beans></beans),@Bean 注入一個(gè)類。@Value 注解,使用${} 從application.yml讀取配置。

DruidConfiguration類

@Configuration 
public class DruidConfiguration { 
  @Bean(name = "vip", initMethod = "init", destroyMethod = "close") 
  public DataSource compare1DataSource( 
      @Value("${spring.datasource.vip.driver-class-name}") String driver, 
      @Value("${spring.datasource.vip.url}") String url, 
      @Value("${spring.datasource.vip.username}") String username, 
      @Value("${spring.datasource.vip.password}") String password, 
      @Value("${spring.datasource.vip.minIdle}") int minIdle, 
      @Value("${spring.datasource.vip.maxActive}") int maxActive, 
      @Value("${spring.datasource.vip.initialSize}") int initialSize, 
      @Value("${spring.datasource.vip.timeBetweenEvictionRunsMillis}") long timeBetweenEvictionRunsMillis, 
      @Value("${spring.datasource.vip.minEvictableIdleTimeMillis}") long minEvictableIdleTimeMillis, 
      @Value("${spring.datasource.vip.validationQuery}") String validationQuery, 
      @Value("${spring.datasource.vip.testWhileIdle}") boolean testWhileIdle, 
      @Value("${spring.datasource.vip.testOnBorrow}") boolean testOnBorrow, 
      @Value("${spring.datasource.vip.testOnReturn}") boolean testOnReturn) { 
    DruidDataSource druidDataSource = new DruidDataSource(); 
    druidDataSource.setDriverClassName(driver); 
    druidDataSource.setUrl(url); 
    druidDataSource.setUsername(username); 
    druidDataSource.setPassword(password); 
    druidDataSource.setMinIdle(minIdle); 
    druidDataSource.setMaxActive(maxActive); 
    druidDataSource.setInitialSize(initialSize); 
    druidDataSource 
        .setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis); 
    druidDataSource 
        .setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis); 
    druidDataSource.setValidationQuery(validationQuery); 
    druidDataSource.setTestWhileIdle(testWhileIdle); 
    druidDataSource.setTestOnBorrow(testOnBorrow); 
    druidDataSource.setTestOnReturn(testOnReturn); 
    return druidDataSource; 
  } 
 
} 

2、指定domain類、mapper接口,xml配件文件的路徑,并指定映射關(guān)系

@MapperScan 注解,掃描該包名下的所有文件。

@Autowired+@Qualifier 注入 上面已經(jīng)聲明的 datasource 類

@Configuration 
@MapperScan(basePackages = { "com.zto.merchantPlatform.mapper.vip" }, sqlSessionFactoryRef = "vipSqlSessionFactory") 
public class VipMybatisConfiguration { 
 
  @Autowired 
  @Qualifier("vip") 
  private DataSource dataSource; 
   
  @Bean(name = "vipSqlSessionFactory") 
  public SqlSessionFactoryBean sqlSessionFactory(@Value("${mybatis.vip.mapperLocations}") String mapperLocations,  
      @Value("${mybatis.vip.typeAliasesPackage}")String typeAliasesPackage) throws Exception { 
    SqlSessionFactoryBean sessionFactoryBean = new SqlSessionFactoryBean(); 
    sessionFactoryBean.setDataSource(dataSource); 
    sessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources(mapperLocations)); 
    sessionFactoryBean.setTypeAliasesPackage(typeAliasesPackage); 
    return sessionFactoryBean; 
  } 
 
  @Bean(name = "vipTransactionManager") 
  public DataSourceTransactionManager transactionManager() { 
    return new DataSourceTransactionManager(dataSource); 
  } 
} 

3、mapper接口對(duì)應(yīng)的xml文件

4、數(shù)據(jù)源配置文件

5、指定mybatis下的mapper和xml文件的之間的映射關(guān)系。

6、mapper接口(即該庫(kù)下的所有表)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Springcloud中的region和zone的使用實(shí)例

    Springcloud中的region和zone的使用實(shí)例

    這篇文章主要介紹了Springcloud中的region和zone的使用實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • java?讀寫(xiě)鎖的使用及它的優(yōu)點(diǎn)

    java?讀寫(xiě)鎖的使用及它的優(yōu)點(diǎn)

    這篇文章主要介紹了java?讀寫(xiě)鎖的使用及它的優(yōu)點(diǎn),讀寫(xiě)鎖的特點(diǎn)就是是讀讀不互斥、讀寫(xiě)互斥、寫(xiě)寫(xiě)互斥,下面具體使用分享需要的小伙伴可以參考一下
    2022-05-05
  • Java實(shí)現(xiàn)解壓zip壓縮包的兩種方法(支持多層級(jí))

    Java實(shí)現(xiàn)解壓zip壓縮包的兩種方法(支持多層級(jí))

    壓縮文件在生活中經(jīng)常能用到,在Java中提供了壓縮和解壓縮文件的功能,本文主要介紹了Java實(shí)現(xiàn)解壓zip壓縮包的兩種方法(支持多層級(jí)),感興趣的可以了解一下
    2024-03-03
  • 使用MyBatis查詢千萬(wàn)級(jí)數(shù)據(jù)量操作實(shí)現(xiàn)

    使用MyBatis查詢千萬(wàn)級(jí)數(shù)據(jù)量操作實(shí)現(xiàn)

    這篇文章主要為大家介紹了如何使用MyBatis?查詢千萬(wàn)數(shù)據(jù)量的操作過(guò)程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • Spring中的@Repository注解源碼詳解

    Spring中的@Repository注解源碼詳解

    這篇文章主要介紹了Spring中的@Repository注解詳解,@Repository注解修飾哪個(gè)類,則表明這個(gè)類具有對(duì)對(duì)象進(jìn)行增刪改查的功能,而且@Repository是@Component注解的一個(gè)派生品,所以被@Repository注解的類可以自動(dòng)的被@ComponentScan通過(guò)路徑掃描給找到,需要的朋友可以參考下
    2023-10-10
  • 分析Java非阻塞算法Lock-Free的實(shí)現(xiàn)

    分析Java非阻塞算法Lock-Free的實(shí)現(xiàn)

    非阻塞算法一般會(huì)使用CAS來(lái)協(xié)調(diào)線程的操作。雖然非阻塞算法有諸多優(yōu)點(diǎn),但是在實(shí)現(xiàn)上要比基于鎖的算法更加繁瑣和負(fù)責(zé)。本文將會(huì)介紹兩個(gè)是用非阻塞算法實(shí)現(xiàn)的數(shù)據(jù)結(jié)構(gòu)。
    2021-06-06
  • Java操作Mongodb數(shù)據(jù)庫(kù)實(shí)現(xiàn)數(shù)據(jù)的增刪查改功能示例

    Java操作Mongodb數(shù)據(jù)庫(kù)實(shí)現(xiàn)數(shù)據(jù)的增刪查改功能示例

    這篇文章主要介紹了Java操作Mongodb數(shù)據(jù)庫(kù)實(shí)現(xiàn)數(shù)據(jù)的增刪查改功能,結(jié)合完整實(shí)例形式分析了java針對(duì)MongoDB數(shù)據(jù)庫(kù)的連接、增刪改查等相關(guān)操作技巧,需要的朋友可以參考下
    2017-08-08
  • Java中的CountDownLatch簡(jiǎn)單理解

    Java中的CountDownLatch簡(jiǎn)單理解

    這篇文章主要介紹了Java中的CountDownLatch簡(jiǎn)單理解,CountDownLatch是一個(gè)同步工具類,用來(lái)攜調(diào)多個(gè)線程之間的同步,它是是使用一個(gè)計(jì)數(shù)器進(jìn)行實(shí)現(xiàn)的,計(jì)數(shù)器初始值為線程數(shù)量,需要的朋友可以參考下
    2024-01-01
  • Spring Boot Swagger2使用方法過(guò)程解析

    Spring Boot Swagger2使用方法過(guò)程解析

    這篇文章主要介紹了Spring Boot Swagger2使用方法過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-08-08
  • Java從源碼看異步任務(wù)計(jì)算FutureTask

    Java從源碼看異步任務(wù)計(jì)算FutureTask

    這篇文章主要介紹了Java從源碼看異步任務(wù)計(jì)算FutureTask,F(xiàn)utureTask就能夠很好的幫助我們實(shí)現(xiàn)異步計(jì)算,并且可以實(shí)現(xiàn)同步獲取異步任務(wù)的計(jì)算結(jié)果,具體是怎樣實(shí)現(xiàn)的,下面我們就一起來(lái)學(xué)習(xí)下面文章的具體內(nèi)容吧
    2022-04-04

最新評(píng)論