欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

多數(shù)據(jù)源怎么利用springboot進(jìn)行配置-創(chuàng)新互聯(lián)

本篇文章給大家分享的是有關(guān)多數(shù)據(jù)源怎么利用spring boot進(jìn)行配置,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比大連網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式大連網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋大連地區(qū)。費(fèi)用合理售后完善,十多年實(shí)體公司更值得信賴。

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

創(chuàng)建一個(gè)Spring配置類,定義兩個(gè)DataSource用來(lái)讀取application.properties中的不同配置。如下例子中,主數(shù)據(jù)源配置為spring.datasource.primary開(kāi)頭的配置,第二數(shù)據(jù)源配置為spring.datasource.secondary開(kāi)頭的配置。

@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();
  }
}

對(duì)應(yīng)的application.properties配置如下:

spring.datasource.primary.url=jdbc:mysql://localhost:3306/test1
spring.datasource.primary.username=root
spring.datasource.primary.password=root
spring.datasource.primary.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.secondary.url=jdbc:mysql://localhost:3306/test2
spring.datasource.secondary.username=root
spring.datasource.secondary.password=root
spring.datasource.secondary.driver-class-name=com.mysql.jdbc.Driver

JdbcTemplate支持

對(duì)JdbcTemplate的支持比較簡(jiǎn)單,只需要為其注入對(duì)應(yīng)的datasource即可,如下例子,在創(chuàng)建JdbcTemplate的時(shí)候分別注入名為primaryDataSource和secondaryDataSource的數(shù)據(jù)源來(lái)區(qū)分不同的JdbcTemplate。

@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);
}

接下來(lái)通過(guò)測(cè)試用例來(lái)演示如何使用這兩個(gè)針對(duì)不同數(shù)據(jù)源的JdbcTemplate。

@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(Application.class)
public class ApplicationTests {
  @Autowired
  @Qualifier("primaryJdbcTemplate")
  protected JdbcTemplate jdbcTemplate1;
  @Autowired
  @Qualifier("secondaryJdbcTemplate")
  protected JdbcTemplate jdbcTemplate2;
  @Before
  public void setUp() {
    jdbcTemplate1.update("DELETE FROM USER ");
    jdbcTemplate2.update("DELETE FROM USER ");
  }
  @Test
  public void test() throws Exception {
    // 往第一個(gè)數(shù)據(jù)源中插入兩條數(shù)據(jù)
    jdbcTemplate1.update("insert into user(id,name,age) values(?, ?, ?)", 1, "aaa", 20);
    jdbcTemplate1.update("insert into user(id,name,age) values(?, ?, ?)", 2, "bbb", 30);
    // 往第二個(gè)數(shù)據(jù)源中插入一條數(shù)據(jù),若插入的是第一個(gè)數(shù)據(jù)源,則會(huì)主鍵沖突報(bào)錯(cuò)
    jdbcTemplate2.update("insert into user(id,name,age) values(?, ?, ?)", 1, "aaa", 20);
    // 查一下第一個(gè)數(shù)據(jù)源中是否有兩條數(shù)據(jù),驗(yàn)證插入是否成功
    Assert.assertEquals("2", jdbcTemplate1.queryForObject("select count(1) from user", String.class));
    // 查一下第一個(gè)數(shù)據(jù)源中是否有兩條數(shù)據(jù),驗(yàn)證插入是否成功
    Assert.assertEquals("1", jdbcTemplate2.queryForObject("select count(1) from user", String.class));
  }
}

完整示例:Chapter3-2-3

Spring-data-jpa支持

對(duì)于數(shù)據(jù)源的配置可以沿用上例中DataSourceConfig的實(shí)現(xiàn)。

新增對(duì)第一數(shù)據(jù)源的JPA配置,注意兩處注釋的地方,用于指定數(shù)據(jù)源對(duì)應(yīng)的Entity實(shí)體和Repository定義位置,用@Primary區(qū)分主數(shù)據(jù)源。

新增對(duì)第二數(shù)據(jù)源的JPA配置,內(nèi)容與第一數(shù)據(jù)源類似,具體如下:

@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(
    entityManagerFactoryRef="entityManagerFactorySecondary",
    transactionManagerRef="transactionManagerSecondary",
    basePackages= { "com.didispace.domain.s" }) //設(shè)置Repository所在位置
public class SecondaryConfig {
  @Autowired @Qualifier("secondaryDataSource")
  private DataSource secondaryDataSource;
  @Bean(name = "entityManagerSecondary")
  public EntityManager entityManager(EntityManagerFactoryBuilder builder) {
    return entityManagerFactorySecondary(builder).getObject().createEntityManager();
  }
  @Bean(name = "entityManagerFactorySecondary")
  public LocalContainerEntityManagerFactoryBean entityManagerFactorySecondary (EntityManagerFactoryBuilder builder) {
    return builder
        .dataSource(secondaryDataSource)
        .properties(getVendorProperties(secondaryDataSource))
        .packages("com.didispace.domain.s") //設(shè)置實(shí)體類所在位置
        .persistenceUnit("secondaryPersistenceUnit")
        .build();
  }
  @Autowired
  private JpaProperties jpaProperties;
  private Map<String, String> getVendorProperties(DataSource dataSource) {
    return jpaProperties.getHibernateProperties(dataSource);
  }
  @Bean(name = "transactionManagerSecondary")
  PlatformTransactionManager transactionManagerSecondary(EntityManagerFactoryBuilder builder) {
    return new JpaTransactionManager(entityManagerFactorySecondary(builder).getObject());
  }
}

完成了以上配置之后,主數(shù)據(jù)源的實(shí)體和數(shù)據(jù)訪問(wèn)對(duì)象位于:com.didispace.domain.p,次數(shù)據(jù)源的實(shí)體和數(shù)據(jù)訪問(wèn)接口位于:com.didispace.domain.s。

分別在這兩個(gè)package下創(chuàng)建各自的實(shí)體和數(shù)據(jù)訪問(wèn)接口

主數(shù)據(jù)源下,創(chuàng)建User實(shí)體和對(duì)應(yīng)的Repository接口

@Entity
public class User {
  @Id
  @GeneratedValue
  private Long id;
  @Column(nullable = false)
  private String name;
  @Column(nullable = false)
  private Integer age;
  public User(){}
  public User(String name, Integer age) {
    this.name = name;
    this.age = age;
  }
  // 省略getter、setter
}

public interface UserRepository extends JpaRepository<User, Long> {
}

從數(shù)據(jù)源下,創(chuàng)建Message實(shí)體和對(duì)應(yīng)的Repository接口

@Entity
public class Message {
  @Id
  @GeneratedValue
  private Long id;
  @Column(nullable = false)
  private String name;
  @Column(nullable = false)
  private String content;
  public Message(){}
  public Message(String name, String content) {
    this.name = name;
    this.content = content;
  }
  // 省略getter、setter
}
public interface MessageRepository extends JpaRepository<Message, Long> {
}

接下來(lái)通過(guò)測(cè)試用例來(lái)驗(yàn)證使用這兩個(gè)針對(duì)不同數(shù)據(jù)源的配置進(jìn)行數(shù)據(jù)操作。

@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(Application.class)
public class ApplicationTests {
  @Autowired
  private UserRepository userRepository;
  @Autowired
  private MessageRepository messageRepository;
  @Test
  public void test() throws Exception {
    userRepository.save(new User("aaa", 10));
    userRepository.save(new User("bbb", 20));
    userRepository.save(new User("ccc", 30));
    userRepository.save(new User("ddd", 40));
    userRepository.save(new User("eee", 50));
    Assert.assertEquals(5, userRepository.findAll().size());
    messageRepository.save(new Message("o1", "aaaaaaaaaa"));
    messageRepository.save(new Message("o2", "bbbbbbbbbb"));
    messageRepository.save(new Message("o3", "cccccccccc"));
    Assert.assertEquals(3, messageRepository.findAll().size());
  }
}

以上就是多數(shù)據(jù)源怎么利用spring boot進(jìn)行配置,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)站標(biāo)題:多數(shù)據(jù)源怎么利用springboot進(jìn)行配置-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)鏈接:http://aaarwkj.com/article0/pisio.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站品牌網(wǎng)站設(shè)計(jì)、企業(yè)網(wǎng)站制作、網(wǎng)站設(shè)計(jì)公司品牌網(wǎng)站建設(shè)、電子商務(wù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)
高颜值美女后入内射视频| 亚洲成人日韩国产欧美| 人妻天堂久久一区二区三区| 人妻中文字幕在线av| 国产黄片a三级久久久久久| 99人妻精品一区二区| 欧美激情一区二区亚洲专区| 亚洲av一区二区在线看| 久久精品人妻麻豆尤物| 色婷婷亚洲综合色一区二区| 日本一区二区三区免费看视频| 亚洲av一区二区在线看| 中文精品字幕人妻熟女小妇| 免费在线一区二区av| 午夜免费福利视频一区| 国产日本欧美一区二区三区 | 日韩精品日本道欧美黄片| 日本最新一区二区三区视频| 99久久久国产精品蜜臀| 成人爱爱在线视频免费观看| 日韩精品在线播放观看| 亚洲一区二区三区熟妇| 蜜桃av在线播放视频| 本色啪啪人妻夜嗨嗨av| 欧美三级亚洲三级日韩三级| 可以免费看的欧美黄片| 久久精品成人无码观看56| 国产成人av在线观看| 国产精品欧美日韩中文| 女同久久精品国产精品天堂99| 国产深夜福利在线观看| 欧美 成人一区二区三区| 色婷婷激情一区二区三区| 亚洲国产精品va在线香蕉| 精品午夜人妻一区二区| 亚洲国产成人91精品| 日本黄色录像黄色录像| 日麻批视频在线免费观看| av中文字幕在线电影| 亚洲成人日韩成人av| 91亚洲精品久久久蜜桃网站|