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

Spring Jpa多數(shù)據(jù)源工程配置過程解析

 更新時(shí)間:2020年08月17日 11:12:48   作者:柒丶月  
這篇文章主要介紹了Spring Jpa多數(shù)據(jù)源工程配置過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

工程創(chuàng)建

首先是創(chuàng)建一個(gè)Spring Boot工程,創(chuàng)建時(shí)添加基本的Web、Jpa以及MySQL依賴,如下:

創(chuàng)建完成后,添加Druid依賴,這里和前文的要求一樣,要使用專為Spring Boot打造的Druid,大伙可能發(fā)現(xiàn)了,如果整合多數(shù)據(jù)源一定要使用這個(gè)依賴,因?yàn)檫@個(gè)依賴中才有DruidDataSourceBuilder,最后還要記得鎖定數(shù)據(jù)庫依賴的版本,因?yàn)榭赡艽蟛糠秩擞玫倪€是5.x的MySQL而不是8.x。完整依賴如下:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>druid-spring-boot-starter</artifactId>
  <version>1.1.10</version>
</dependency>
<dependency>
  <groupId>mysql</groupId>
  <artifactId>mysql-connector-java</artifactId>
  <version>5.1.28</version>
  <scope>runtime</scope>
</dependency>

如此之后,工程就創(chuàng)建成功了。

基本配置

在基本配置中,我們首先來配置多數(shù)據(jù)源基本信息以及DataSource,首先在application.properties中添加如下配置信息:

# 數(shù)據(jù)源一
spring.datasource.one.username=root
spring.datasource.one.password=root
spring.datasource.one.url=jdbc:mysql:///test01?useUnicode=true&characterEncoding=UTF-8
spring.datasource.one.type=com.alibaba.druid.pool.DruidDataSource

# 數(shù)據(jù)源二
spring.datasource.two.username=root
spring.datasource.two.password=root
spring.datasource.two.url=jdbc:mysql:///test02?useUnicode=true&characterEncoding=UTF-8
spring.datasource.two.type=com.alibaba.druid.pool.DruidDataSource

# Jpa配置
spring.jpa.properties.database=mysql
spring.jpa.properties.show-sql=true
spring.jpa.properties.database-platform=mysql
spring.jpa.properties.hibernate.ddl-auto=update
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL57Dialect

這里Jpa的配置和上文相比key中多了properties,多數(shù)據(jù)源的配置和前文一致,然后接下來配置兩個(gè)DataSource,如下:

@Configuration
public class DataSourceConfig {
  @Bean
  @ConfigurationProperties(prefix = "spring.datasource.one")
  @Primary
  DataSource dsOne() {
    return DruidDataSourceBuilder.create().build();
  }
  @Bean
  @ConfigurationProperties(prefix = "spring.datasource.two")
  DataSource dsTwo() {
    return DruidDataSourceBuilder.create().build();
  }
}

這里的配置和前文的多數(shù)據(jù)源配置基本一致,但是注意多了一個(gè)在Spring中使用較少的注解@Primary,這個(gè)注解一定不能少,否則在項(xiàng)目啟動(dòng)時(shí)會(huì)出錯(cuò),@Primary表示當(dāng)某一個(gè)類存在多個(gè)實(shí)例時(shí),優(yōu)先使用哪個(gè)實(shí)例。

好了,這樣,DataSource就有了。

多數(shù)據(jù)源配置

接下來配置Jpa的基本信息,這里兩個(gè)數(shù)據(jù)源,我分別在兩個(gè)類中來配置,先來看第一個(gè)配置:

@Configuration
@EnableJpaRepositories(basePackages = "org.sang.jpa.dao",entityManagerFactoryRef = "localContainerEntityManagerFactoryBeanOne",transactionManagerRef = "platformTransactionManagerOne")
public class JpaConfigOne {
  @Autowired
  @Qualifier(value = "dsOne")
  DataSource dsOne;

  @Autowired
  JpaProperties jpaProperties;

  @Bean
  @Primary
  LocalContainerEntityManagerFactoryBean localContainerEntityManagerFactoryBeanOne(EntityManagerFactoryBuilder builder) {
    return builder.dataSource(dsOne)
        .packages("org.sang.jpa.model")
        .properties(jpaProperties.getProperties())
        .persistenceUnit("pu1")
        .build();
  }

  @Bean
  PlatformTransactionManager platformTransactionManagerOne(EntityManagerFactoryBuilder builder) {
    LocalContainerEntityManagerFactoryBean factoryBeanOne = localContainerEntityManagerFactoryBeanOne(builder);
    return new JpaTransactionManager(factoryBeanOne.getObject());
  }
}

首先這里注入dsOne,再注入JpaProperties,JpaProperties是系統(tǒng)提供的一個(gè)實(shí)例,里邊的數(shù)據(jù)就是我們?cè)赼pplication.properties中配置的jpa相關(guān)的配置。然后我們提供兩個(gè)Bean,分別是LocalContainerEntityManagerFactoryBean和PlatformTransactionManager事務(wù)管理器,不同于MyBatis和JdbcTemplate,在Jpa中,事務(wù)一定要配置。在提供LocalContainerEntityManagerFactoryBean的時(shí)候,需要指定packages,這里的packages指定的包就是這個(gè)數(shù)據(jù)源對(duì)應(yīng)的實(shí)體類所在的位置,另外在這里配置類上通過@EnableJpaRepositories注解指定dao所在的位置,以及LocalContainerEntityManagerFactoryBean和PlatformTransactionManager分別對(duì)應(yīng)的引用的名字。

好了,這樣第一個(gè)就配置好了,第二個(gè)基本和這個(gè)類似,主要有幾個(gè)不同點(diǎn):

  • dao的位置不同
  • persistenceUnit不同
  • 相關(guān)bean的名稱不同

注意實(shí)體類可以共用。

代碼如下:

@Configuration
@EnableJpaRepositories(basePackages = "org.sang.jpa.dao2",entityManagerFactoryRef = "localContainerEntityManagerFactoryBeanTwo",transactionManagerRef = "platformTransactionManagerTwo")
public class JpaConfigTwo {
  @Autowired
  @Qualifier(value = "dsTwo")
  DataSource dsTwo;

  @Autowired
  JpaProperties jpaProperties;

  @Bean
  LocalContainerEntityManagerFactoryBean localContainerEntityManagerFactoryBeanTwo(EntityManagerFactoryBuilder builder) {
    return builder.dataSource(dsTwo)
        .packages("org.sang.jpa.model")
        .properties(jpaProperties.getProperties())
        .persistenceUnit("pu2")
        .build();
  }

  @Bean
  PlatformTransactionManager platformTransactionManagerTwo(EntityManagerFactoryBuilder builder) {
    LocalContainerEntityManagerFactoryBean factoryBeanTwo = localContainerEntityManagerFactoryBeanTwo(builder);
    return new JpaTransactionManager(factoryBeanTwo.getObject());
  }
}

接下來,在對(duì)應(yīng)位置分別提供相關(guān)的實(shí)體類和dao即可,數(shù)據(jù)源一的dao如下:

package org.sang.jpa.dao;
public interface UserDao extends JpaRepository<User,Integer> {
  List<User> getUserByAddressEqualsAndIdLessThanEqual(String address, Integer id);

  @Query(value = "select * from t_user where id=(select max(id) from t_user)",nativeQuery = true)
  User maxIdUser();
}

數(shù)據(jù)源二的dao如下:

package org.sang.jpa.dao2;

public interface UserDao2 extends JpaRepository<User,Integer> {
  List<User> getUserByAddressEqualsAndIdLessThanEqual(String address, Integer id);

  @Query(value = "select * from t_user where id=(select max(id) from t_user)",nativeQuery = true)
  User maxIdUser();
}

共同的實(shí)體類如下:

package org.sang.jpa.model;

@Entity(name = "t_user")
public class User {
  @Id
  @GeneratedValue(strategy = GenerationType.IDENTITY)
  private Integer id;
  private String username;
  private String address;
  //省略getter/setter
}

到此,所有的配置就算完成了,接下來就可以在Service中注入不同的UserDao,不同的UserDao操作不同的數(shù)據(jù)源。

其實(shí)整合Jpa多數(shù)據(jù)源也不算難,就是有幾個(gè)細(xì)節(jié)問題,這些細(xì)節(jié)問題解決,其實(shí)前面介紹的其他多數(shù)據(jù)源整個(gè)都差不多。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java和Android崩潰捕獲機(jī)制

    Java和Android崩潰捕獲機(jī)制

    這篇文章主要為大家介紹了Java和Android崩潰捕獲機(jī)制詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • 使用MongoClient連接Mongodb問題

    使用MongoClient連接Mongodb問題

    這篇文章主要介紹了使用MongoClient連接Mongodb問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • Java使用Thread創(chuàng)建多線程并啟動(dòng)操作示例

    Java使用Thread創(chuàng)建多線程并啟動(dòng)操作示例

    這篇文章主要介紹了Java使用Thread創(chuàng)建多線程并啟動(dòng)操作,結(jié)合實(shí)例形式分析了Java基于Thread類的多線程定義與啟動(dòng)簡(jiǎn)單操作技巧,需要的朋友可以參考下
    2018-06-06
  • Maven中錯(cuò)誤使用parent.relativePath導(dǎo)致構(gòu)建失敗問題

    Maven中錯(cuò)誤使用parent.relativePath導(dǎo)致構(gòu)建失敗問題

    這篇文章主要介紹了Maven中錯(cuò)誤使用parent.relativePath導(dǎo)致構(gòu)建失敗問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • SpringBoot+MyBatis-Plus實(shí)現(xiàn)分頁功能

    SpringBoot+MyBatis-Plus實(shí)現(xiàn)分頁功能

    在SpringBoot項(xiàng)目中,結(jié)合MyBatis-Plus(簡(jiǎn)稱MP)可以非常方便地實(shí)現(xiàn)分頁功能,MP為開發(fā)者提供了分頁插件PaginationInterceptor,只需簡(jiǎn)單配置即可使用,本文給大家介紹了SpringBoot+MyBatis-Plus實(shí)現(xiàn)分頁功能,文中通過代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2024-01-01
  • java實(shí)現(xiàn)數(shù)字轉(zhuǎn)換人民幣中文大寫工具

    java實(shí)現(xiàn)數(shù)字轉(zhuǎn)換人民幣中文大寫工具

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)數(shù)字轉(zhuǎn)換人民幣中文大寫工具,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • Java讀取txt文件中的數(shù)據(jù)賦給String變量方法

    Java讀取txt文件中的數(shù)據(jù)賦給String變量方法

    今天小編就為大家分享一篇Java讀取txt文件中的數(shù)據(jù)賦給String變量方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • Java中使用Properties配置文件的簡(jiǎn)單方法

    Java中使用Properties配置文件的簡(jiǎn)單方法

    這篇文章主要給大家介紹了關(guān)于Java中使用Properties配置文件的簡(jiǎn)單方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • java常用工具類之?dāng)?shù)據(jù)庫連接類(可以連接多種數(shù)據(jù)庫)

    java常用工具類之?dāng)?shù)據(jù)庫連接類(可以連接多種數(shù)據(jù)庫)

    這篇文章主要介紹了java常用工具類之?dāng)?shù)據(jù)庫連接類,可以連接多種數(shù)據(jù)庫,代碼中包含詳細(xì)注釋,需要的朋友可以參考下
    2014-07-07
  • java 中死鎖問題的實(shí)例詳解

    java 中死鎖問題的實(shí)例詳解

    這篇文章主要介紹了java 中死鎖問題的實(shí)例詳解的相關(guān)資料,希望通過本文大家能夠理解掌握死鎖的問題,需要的朋友可以參考下
    2017-09-09

最新評(píng)論