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

在SpringBoot中整合數(shù)據(jù)源的示例詳解

 更新時(shí)間:2023年06月29日 15:17:36   作者:萬貓學(xué)社  
這篇文章主要介紹了在SpringBoot中如何整合數(shù)據(jù)源,本文介紹了如何在SpringBoot項(xiàng)目中整合常見的數(shù)據(jù)源,包括JdbcTemplate、MyBatis和JPA,并探討了如何配置和使用多數(shù)據(jù)源,需要的朋友可以參考下

在企業(yè)級(jí)應(yīng)用開發(fā)中,數(shù)據(jù)存儲(chǔ)是必不可少的一環(huán)。為了簡化數(shù)據(jù)訪問層的開發(fā),SpringBoot提供了對(duì)多種數(shù)據(jù)源的整合支持。本文將介紹如何在SpringBoot項(xiàng)目中整合常見的數(shù)據(jù)源,包括JdbcTemplate、MyBatis和JPA,并探討如何配置和使用多數(shù)據(jù)源。

1. 數(shù)據(jù)源的選擇與配置

1.1. 常見的數(shù)據(jù)源類型

在Java開發(fā)中,常見的數(shù)據(jù)源類型有以下幾種:

  • JDBC:Java數(shù)據(jù)庫連接,是Java訪問數(shù)據(jù)庫的標(biāo)準(zhǔn)API。使用JDBC可以直接操作數(shù)據(jù)庫,但需要編寫大量的SQL語句和處理結(jié)果集,開發(fā)效率較低。
  • JdbcTemplate:基于JDBC的一個(gè)封裝庫,簡化了JDBC的使用,提高了開發(fā)效率。
  • MyBatis:一個(gè)優(yōu)秀的持久層框架,支持定制化SQL、存儲(chǔ)過程以及高級(jí)映射。MyBatis避免了幾乎所有的JDBC代碼和手動(dòng)設(shè)置參數(shù)以及獲取結(jié)果集。
  • JPA:Java持久化API,是一種ORM(對(duì)象關(guān)系映射)規(guī)范,實(shí)現(xiàn)了對(duì)象模型和關(guān)系型數(shù)據(jù)庫之間的映射。Hibernate是JPA的一種實(shí)現(xiàn)。

1.2. 數(shù)據(jù)源配置文件的編寫

在SpringBoot項(xiàng)目中,我們通常在application.propertiesapplication.yml文件中配置數(shù)據(jù)源。以下是一個(gè)典型的數(shù)據(jù)源配置示例:

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/test
    username: root
    password: 123456
    driver-class-name: com.mysql.cj.jdbc.Driver

其中,url指定了數(shù)據(jù)庫的連接地址,usernamepassword分別表示數(shù)據(jù)庫的用戶名和密碼,driver-class-name是數(shù)據(jù)庫驅(qū)動(dòng)類的全限定名。

1.3. SpringBoot自動(dòng)配置數(shù)據(jù)源的原理

在SpringBoot中,數(shù)據(jù)源的配置得到了極大的簡化,這得益于其自動(dòng)配置的特性。一旦我們?cè)陧?xiàng)目中添加了相應(yīng)的依賴并正確配置了數(shù)據(jù)源信息,SpringBoot便會(huì)自動(dòng)創(chuàng)建一個(gè)DataSource對(duì)象,并將其注冊(cè)到Spring容器中,從而實(shí)現(xiàn)了數(shù)據(jù)源的自動(dòng)化管理。

具體而言,SpringBoot會(huì)根據(jù)項(xiàng)目中的依賴來智能選擇合適的數(shù)據(jù)源實(shí)現(xiàn)。例如,如果項(xiàng)目中引入了HikariCP、Tomcat連接池或者C3P0等依賴,SpringBoot會(huì)自動(dòng)選擇并使用這些數(shù)據(jù)源實(shí)現(xiàn)。而在沒有引入這些依賴的情況下,SpringBoot則會(huì)采用默認(rèn)的數(shù)據(jù)源實(shí)現(xiàn)。

通過這種方式,SpringBoot為我們提供了一種簡潔、高效的數(shù)據(jù)源配置方法,使得我們能夠更專注于業(yè)務(wù)邏輯的實(shí)現(xiàn),而無需過多關(guān)注底層的數(shù)據(jù)源配置細(xì)節(jié)。

2. SpringBoot整合JdbcTemplate

2.1. JdbcTemplate的簡介與作用

JdbcTemplate是Spring框架中提供的一個(gè)簡化JDBC操作的工具類,它可以幫助我們避免編寫大量的重復(fù)代碼,提高開發(fā)效率。JdbcTemplate主要提供了以下功能:

  • 簡化數(shù)據(jù)庫連接的獲取和釋放;
  • 簡化SQL語句的執(zhí)行;
  • 簡化結(jié)果集的處理。

2.2. 在SpringBoot中配置JdbcTemplate

要在SpringBoot項(xiàng)目中使用JdbcTemplate,首先需要引入相關(guān)依賴:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

然后,在配置文件中配置數(shù)據(jù)源信息,如前文所述。

最后,在需要使用JdbcTemplate的地方,通過@Autowired注解注入JdbcTemplate對(duì)象:

@Autowired
private JdbcTemplate jdbcTemplate;

2.3. 使用JdbcTemplate進(jìn)行數(shù)據(jù)庫操作

使用JdbcTemplate進(jìn)行數(shù)據(jù)庫操作非常簡單,以下是一個(gè)簡單的示例:

public List<User> findAllUsers() {
  String sql = "SELECT * FROM user";
  return jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class));
}

在這個(gè)示例中,我們使用JdbcTemplate的query方法執(zhí)行了一個(gè)查詢語句,并將結(jié)果集映射為User對(duì)象的列表。這里使用了BeanPropertyRowMapper作為結(jié)果集的映射器,它會(huì)自動(dòng)將結(jié)果集中的列映射到Java對(duì)象的屬性上。

3. SpringBoot整合MyBatis

3.1. MyBatis的簡介與作用

MyBatis是一個(gè)優(yōu)秀的持久層框架,它支持定制化SQL、存儲(chǔ)過程以及高級(jí)映射。MyBatis避免了幾乎所有的JDBC代碼和手動(dòng)設(shè)置參數(shù)以及獲取結(jié)果集。MyBatis的主要特點(diǎn)包括:

  • 靈活的SQL編寫,支持動(dòng)態(tài)SQL;
  • 易于集成,可以與Spring、SpringBoot等框架無縫集成;
  • 支持多種數(shù)據(jù)庫和多種數(shù)據(jù)源;
  • 提供了豐富的映射類型,支持一對(duì)一、一對(duì)多等關(guān)聯(lián)查詢。

3.2. 在SpringBoot中配置MyBatis

要在SpringBoot項(xiàng)目中使用MyBatis,首先需要引入相關(guān)依賴:

<dependency>
  <groupId>org.mybatis.spring.boot</groupId>
  <artifactId>mybatis-spring-boot-starter</artifactId>
  <version>2.1.4</version>
</dependency>

然后,在配置文件中配置數(shù)據(jù)源信息和MyBatis的相關(guān)配置,例如:

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/test
    username: root
    password: 123456
    driver-class-name: com.mysql.cj.jdbc.Driver
  mybatis:
    mapper-locations: classpath:mapper/*.xml
    type-aliases-package: com.example.demo.entity

其中,mapper-locations指定了MyBatis的映射文件的位置,type-aliases-package指定了實(shí)體類的包名。

3.3. 使用MyBatis進(jìn)行數(shù)據(jù)庫操作

使用MyBatis進(jìn)行數(shù)據(jù)庫操作需要編寫Mapper接口和映射文件。以下是一個(gè)簡單的示例:

編寫Mapper接口:

public interface UserMapper {
  List<User> findAll();
}

編寫映射文件:

<mapper namespace="com.example.demo.mapper.UserMapper">
  <select id="findAll" resultType="User">
    SELECT * FROM user
  </select>
</mapper>

在需要使用UserMapper的地方,通過@Autowired注解注入U(xiǎn)serMapper對(duì)象:

@Autowired
private UserMapper userMapper;

調(diào)用UserMapper的方法進(jìn)行數(shù)據(jù)庫操作:

public List<User> findAllUsers() {
  return userMapper.findAll();
}

4. SpringBoot整合JPA

4.1. JPA的簡介與作用

JPA(Java Persistence API)是Java EE 5規(guī)范中的持久化規(guī)范,它的目的是簡化實(shí)體Bean的持久化操作。JPA的主要特點(diǎn)包括:

  • 提供了一種基于注解的對(duì)象關(guān)系映射;
  • 支持多種數(shù)據(jù)庫和多種數(shù)據(jù)源;
  • 提供了豐富的查詢方式,包括JPQL(Java Persistence Query Language)和Criteria API;
  • 支持事務(wù)管理。

4.2. 在SpringBoot中配置JPA

要在SpringBoot項(xiàng)目中使用JPA,首先需要引入相關(guān)依賴:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

然后,在配置文件中配置數(shù)據(jù)源信息和JPA的相關(guān)配置,例如:

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/test
    username: root
    password: 123456
    driver-class-name: com.mysql.cj.jdbc.Driver
  jpa:
    hibernate:
      ddl-auto: update
    show-sql: true

其中,ddl-auto表示Hibernate的自動(dòng)建表策略,show-sql表示是否打印SQL語句。

4.3. 使用JPA進(jìn)行數(shù)據(jù)庫操作

使用JPA進(jìn)行數(shù)據(jù)庫操作需要編寫實(shí)體類和Repository接口。以下是一個(gè)簡單的示例:

編寫實(shí)體類:

@Entity
@Table(name = "user")
public class User {
  @Id
  @GeneratedValue(strategy = GenerationType.IDENTITY)
  private Long id;
  private String name;
  private Integer age;
  // 省略getter和setter方法
}

編寫Repository接口:

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

在需要使用UserRepository的地方,通過@Autowired注解注入U(xiǎn)serRepository對(duì)象:

@Autowired
private UserRepository userRepository;

調(diào)用UserRepository的方法進(jìn)行數(shù)據(jù)庫操作:

public List<User> findAllUsers() {
  return userRepository.findAll();
}

5. 多數(shù)據(jù)源的配置與使用

5.1. 在SpringBoot中配置多數(shù)據(jù)源

在某些場景下,我們需要在一個(gè)項(xiàng)目中使用多個(gè)數(shù)據(jù)源。要在SpringBoot中配置多數(shù)據(jù)源,首先需要在配置文件中配置多個(gè)數(shù)據(jù)源的信息,例如:

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

然后,需要編寫一個(gè)配置類,用于創(chuàng)建多個(gè)數(shù)據(jù)源對(duì)象:

@Configuration
public class DataSourceConfig {
  @Bean
  @Primary
  @ConfigurationProperties(prefix = "spring.datasource.primary")
  public DataSource primaryDataSource() {
    return DataSourceBuilder.create().build();
  }
  @Bean
  @ConfigurationProperties(prefix = "spring.datasource.secondary")
  public DataSource secondaryDataSource() {
    return DataSourceBuilder.create().build();
  }
}

5.2. 使用多數(shù)據(jù)源進(jìn)行數(shù)據(jù)庫操作

在配置了多數(shù)據(jù)源之后,我們可以在不同的場景下使用不同的數(shù)據(jù)源。以下是一個(gè)使用多數(shù)據(jù)源的示例:

編寫一個(gè)Service類,用于操作不同的數(shù)據(jù)源:

@Service
public class UserService {
  @Autowired
  @Qualifier("primaryJdbcTemplate")
  private JdbcTemplate primaryJdbcTemplate;
  @Autowired
  @Qualifier("secondaryJdbcTemplate")
  private JdbcTemplate secondaryJdbcTemplate;
  public List<User> findAllUsersFromPrimary() {
    String sql = "SELECT * FROM user";
    return primaryJdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class));
  }
  public List<User> findAllUsersFromSecondary() {
    String sql = "SELECT * FROM user";
    return secondaryJdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class));
  }
}

在需要使用多數(shù)據(jù)源的地方,調(diào)用UserService的方法進(jìn)行數(shù)據(jù)庫操作:

public List<User> findAllUsers() {
  List<User> primaryUsers = userService.findAllUsersFromPrimary();
  List<User> secondaryUsers = userService.findAllUsersFromSecondary();
  return Stream.concat(primaryUsers.stream(), secondaryUsers.stream()).collect(Collectors.toList());
}

總結(jié)

本文介紹了如何在SpringBoot項(xiàng)目中整合常見的數(shù)據(jù)源,包括JdbcTemplate、MyBatis和JPA,并探討了如何配置和使用多數(shù)據(jù)源。通過使用SpringBoot提供的自動(dòng)配置和簡化的API,我們可以輕松地在項(xiàng)目中使用不同的數(shù)據(jù)源,提高開發(fā)效率。

到此這篇關(guān)于在SpringBoot中整合數(shù)據(jù)源的示例詳解的文章就介紹到這了,更多相關(guān)SpringBoot整合數(shù)據(jù)源內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 在SpringBoot環(huán)境中使用Mockito進(jìn)行單元測(cè)試的示例詳解

    在SpringBoot環(huán)境中使用Mockito進(jìn)行單元測(cè)試的示例詳解

    Mockito是一個(gè)流行的Java?mocking框架,它允許開發(fā)者以簡單直觀的方式創(chuàng)建和使用模擬對(duì)象(mocks),Mockito特別適用于在Spring?Boot環(huán)境中進(jìn)行單元測(cè)試,所以本文介紹了在SpringBoot環(huán)境中使用Mockito進(jìn)行單元測(cè)試的示例,需要的朋友可以參考下
    2024-11-11
  • SpringBoot項(xiàng)目導(dǎo)入aliyun oss starter依賴后啟動(dòng)報(bào)錯(cuò)問題

    SpringBoot項(xiàng)目導(dǎo)入aliyun oss starter依賴后啟動(dòng)報(bào)錯(cuò)問題

    這篇文章主要介紹了SpringBoot項(xiàng)目導(dǎo)入aliyun oss starter依賴后啟動(dòng)報(bào)錯(cuò)問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 解決在IDEA下使用JUnit的問題(解決過程)

    解決在IDEA下使用JUnit的問題(解決過程)

    很多朋友跟小編反饋在IDEA下使用JUnit進(jìn)行實(shí)例測(cè)試的時(shí)候出現(xiàn)很多奇葩問題,今天小編通過本文給大家分享idea使用JUnit出現(xiàn)問題及解決過程,感興趣的朋友跟隨小編一起看看吧
    2021-05-05
  • SpringCloud中的灰度路由使用詳解

    SpringCloud中的灰度路由使用詳解

    這篇文章主要介紹了SpringCloud中的灰度路由使用詳解,在微服務(wù)中,?通常為了高可用,?同一個(gè)服務(wù)往往采用集群方式部署,?即同時(shí)存在幾個(gè)相同的服務(wù),而灰度的核心就?是路由,?通過我們特定的策略去調(diào)用目標(biāo)服務(wù)線路,需要的朋友可以參考下
    2023-08-08
  • JMS簡介與ActiveMQ實(shí)戰(zhàn)代碼分享

    JMS簡介與ActiveMQ實(shí)戰(zhàn)代碼分享

    這篇文章主要介紹了JMS簡介與ActiveMQ實(shí)戰(zhàn)代碼分享,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2017-12-12
  • spring boot simple類型cache使用詳解

    spring boot simple類型cache使用詳解

    這篇文章主要介紹了spring boot simple類型cache使用,這里用的不是 redis 的緩存,simple 的緩存默認(rèn)用的是java的ConcurrentHashMap, 單純的simple緩存,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • SpringBoot如何通過配置禁用swagger

    SpringBoot如何通過配置禁用swagger

    這篇文章主要給大家介紹了關(guān)于SpringBoot如何通過配置禁用swagger的相關(guān)資料,Swagger用來在開發(fā)階段方便前后端分離的項(xiàng)目實(shí)戰(zhàn)中,提高前后端人員的工作效率,降低交流成本,但是版本上線之后要是把Swagger帶上去會(huì)存在很大的風(fēng)險(xiǎn),需要的朋友可以參考下
    2023-08-08
  • SpringBoot淺析緩存機(jī)制之Ehcache?2.x應(yīng)用

    SpringBoot淺析緩存機(jī)制之Ehcache?2.x應(yīng)用

    EhCache?是一個(gè)純Java的進(jìn)程內(nèi)緩存框架,具有快速、精干等特點(diǎn)。它是Hibernate中的默認(rèn)緩存框架。Ehcache已經(jīng)發(fā)布了3.1版本。但是本文的講解基于2.x版本
    2022-08-08
  • java用類加載器的5種方式讀取.properties文件

    java用類加載器的5種方式讀取.properties文件

    這篇文章主要介紹了java用類加載器的5種方式讀取.properties文件,詳細(xì)的介紹了這5種方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-11-11
  • Java?Optional的使用技巧與最佳實(shí)踐

    Java?Optional的使用技巧與最佳實(shí)踐

    在?Java?中,Optional?是用于優(yōu)雅處理?null?的容器類,其核心目標(biāo)是?顯式提醒開發(fā)者處理空值場景,避免?NullPointerException,本文給大家介紹Java?Optional的使用技巧,感興趣的朋友一起看看吧
    2025-04-04

最新評(píng)論