欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

2. SpringBoot整合JdbcTemplate

2.1. JdbcTemplate的簡介與作用

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

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

2.2. 在SpringBoot中配置JdbcTemplate

要在SpringBoot項目中使用JdbcTemplate,首先需要引入相關依賴:

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

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

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

@Autowired
private JdbcTemplate jdbcTemplate;

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

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

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

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

3. SpringBoot整合MyBatis

3.1. MyBatis的簡介與作用

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

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

3.2. 在SpringBoot中配置MyBatis

要在SpringBoot項目中使用MyBatis,首先需要引入相關依賴:

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

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

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指定了實體類的包名。

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

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

編寫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注解注入UserMapper對象:

@Autowired
private UserMapper userMapper;

調用UserMapper的方法進行數(shù)據庫操作:

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

4. SpringBoot整合JPA

4.1. JPA的簡介與作用

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

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

4.2. 在SpringBoot中配置JPA

要在SpringBoot項目中使用JPA,首先需要引入相關依賴:

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

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

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的自動建表策略,show-sql表示是否打印SQL語句。

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

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

編寫實體類:

@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注解注入UserRepository對象:

@Autowired
private UserRepository userRepository;

調用UserRepository的方法進行數(shù)據庫操作:

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

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

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

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

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

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

@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ù)據源進行數(shù)據庫操作

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

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

@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ù)據源的地方,調用UserService的方法進行數(shù)據庫操作:

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

總結

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

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

相關文章

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

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

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

    SpringBoot項目導入aliyun oss starter依賴后啟動報錯問題

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

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

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

    SpringCloud中的灰度路由使用詳解

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

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

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

    spring boot simple類型cache使用詳解

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

    SpringBoot如何通過配置禁用swagger

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

    SpringBoot淺析緩存機制之Ehcache?2.x應用

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

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

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

    Java?Optional的使用技巧與最佳實踐

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

最新評論