zoukankan      html  css  js  c++  java
  • Spring Boot学习进阶笔记(四)-多数据源配置(JdbcTemplate、Spring-data-jpa)

    在实际开发过程中,往往我们需要链接多个数据库进行操作,所以多数据源的配置就在所难免了。

    一、JdbcTemplate支持:

    spring boot配置多数据源比较简单

    1)修改配置文件“application.properties”

    spring.datasource.primary.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false

    spring.datasource.primary.username=root

    spring.datasource.primary.password=123456

    spring.datasource.primary.driver-class-name=com.mysql.jdbc.Driver

     

     

    spring.datasource.secondary.url=jdbc:mysql://192.168.2.111:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false

    spring.datasource.secondary.username=root

    spring.datasource.secondary.password=123456

    spring.datasource.secondary.driver-class-name=com.mysql.jdbc.Driver

    2)添加数据类“DataSourceConfig.java”

    import javax.sql.DataSource;

     

    import org.springframework.beans.factory.annotation.Qualifier;

    import org.springframework.boot.autoconfigure.jdbc.DataSourceBuilder;

    import org.springframework.boot.context.properties.ConfigurationProperties;

    import org.springframework.context.annotation.Bean;

    import org.springframework.context.annotation.Configuration;

    import org.springframework.context.annotation.Primary;

    import org.springframework.jdbc.core.JdbcTemplate;

     

    @Configuration

    public class DataSourceConfig {

     

      @Bean(name = "primaryDataSource")

        @Qualifier("primaryDataSource")

        @ConfigurationProperties(prefix="spring.datasource.primary")

        public DataSource primaryDataSource() {

            return DataSourceBuilder.create().build();

        }

     

        @Bean(name = "secondaryDataSource")

        @Qualifier("secondaryDataSource")

        @Primary

        @ConfigurationProperties(prefix="spring.datasource.secondary")

        public DataSource secondaryDataSource() {

            return DataSourceBuilder.create().build();

        }

     

        @Bean(name = "primaryJdbcTemplate")

        public JdbcTemplate primaryJdbcTemplate(

                @Qualifier("primaryDataSource") DataSource dataSource) {

            return new JdbcTemplate(dataSource);

        }

     

        @Bean(name = "secondaryJdbcTemplate")

        public JdbcTemplate secondaryJdbcTemplate(

                @Qualifier("secondaryDataSource") DataSource dataSource) {

            return new JdbcTemplate(dataSource);

        }

     

    }

    3)在service调用的时候根据注解添加不同的JdbcTemplate

    @Autowired

        @Qualifier("primaryJdbcTemplate")

        protected JdbcTemplate jdbcTemplate;

     

    @Autowired

        @Qualifier("secondaryJdbcTemplate")

        protected JdbcTemplate jdbcTemplate2;

     

    @Override

        public Integer getUserCount() {

            return jdbcTemplate.queryForObject("select count(1) from USER", Integer.class);

        }

        

        @Override

        public Integer getUserCount2() {

            return jdbcTemplate2.queryForObject("select count(1) from USER", Integer.class);

        }

     

     

    二、Spring-data-jpa支持:

    1)创建数据源配置类“PrimaryConfig.java”和“SecondConfig.java”,以“”为例子

     

     


    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.beans.factory.annotation.Qualifier;
    import org.springframework.boot.autoconfigure.orm.jpa.JpaProperties;
    import org.springframework.boot.orm.jpa.EntityManagerFactoryBuilder;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.context.annotation.Primary;
    import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
    import org.springframework.orm.jpa.JpaTransactionManager;
    import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
    import org.springframework.transaction.PlatformTransactionManager;
    import org.springframework.transaction.annotation.EnableTransactionManagement;

     

    import javax.persistence.EntityManager;
    import javax.sql.DataSource;
    import java.util.Map;

     

    @Configuration
    @EnableTransactionManagement
    @EnableJpaRepositories(entityManagerFactoryRef = "entityManagerFactoryPrimary", transactionManagerRef = "transactionManagerPrimary", basePackages = { "com.zh.SpringBootDemo.domain.p" }) // 设置Repository所在位置
    public class PrimaryConfig {

     

    @Autowired
    @Qualifier("primaryDataSource")
    private DataSource primaryDataSource;

     

    @Primary
    @Bean(name = "entityManagerPrimary")
    public EntityManager entityManager(EntityManagerFactoryBuilder builder) {
    return entityManagerFactoryPrimary(builder).getObject().createEntityManager();
    }

     

    @Primary
    @Bean(name = "entityManagerFactoryPrimary")
    public LocalContainerEntityManagerFactoryBean entityManagerFactoryPrimary(EntityManagerFactoryBuilder builder) {
    return builder.dataSource(primaryDataSource).properties(getVendorProperties(primaryDataSource)).packages("com.zh.SpringBootDemo.domain.p") // 设置实体类所在位置
    .persistenceUnit("primaryPersistenceUnit").build();
    }

     

    @Autowired
    private JpaProperties jpaProperties;

     

    private Map<String, String> getVendorProperties(DataSource dataSource) {
    return jpaProperties.getHibernateProperties(dataSource);
    }

     

    @Primary
    @Bean(name = "transactionManagerPrimary")
    public PlatformTransactionManager transactionManagerPrimary(EntityManagerFactoryBuilder builder) {
    return new JpaTransactionManager(entityManagerFactoryPrimary(builder).getObject());
    }

     

    }

     

     

    2)创建实体类domain和对应的respository

     

    import org.springframework.data.jpa.repository.JpaRepository;
    import org.springframework.data.jpa.repository.Query;
    import org.springframework.data.repository.query.Param;

     

    public interface UserRepository extends JpaRepository<User, Long> {

     

    User findByName(String name);

     

    User findByNameAndAge(String name, Integer age);

     

    @Query("from User u where u.name=:name")
    User findUser(@Param("name") String name);

     


    }

     

     

    3)根据注解调用对应的respository即可

     

  • 相关阅读:
    黑马程序员——JAVA基础之主函数main和静态static,静态代码块
    黑马程序员——JAVA基础之final this.和super.的区别
    黑马程序员——JAVA基础之构造函数,构造代码块
    黑马程序员——JAVA基础之简述 类的封装
    黑马程序员——JAVA基础之简述面向对象,类,变量,匿名对象
    NBU Rman异机恢复Oracle
    Oracle的Rman差异增量备份
    rman备份出现ORA-19625
    查询rman备份信息常用指令
    RMAN-06172: no AUTOBACKUP found or specified handle is not a valid copy or piece
  • 原文地址:https://www.cnblogs.com/lovechengyu/p/7117264.html
Copyright © 2011-2022 走看看