Spring Boot-데이터베이스 처리

Spring Boot는 데이터베이스 용 데이터 소스를 만드는 데 매우 좋은 지원을 제공합니다. Spring Boot에서 DataSource를 만들기 위해 추가 코드를 작성할 필요가 없습니다. 종속성을 추가하고 구성 세부 정보를 수행하는 것만으로도 DataSource를 만들고 데이터베이스를 연결하는 데 충분합니다.

이 장에서는 Spring Boot JDBC 드라이버 연결을 사용하여 데이터베이스를 연결합니다.

먼저 빌드 구성 파일에 Spring Boot Starter JDBC 종속성을 추가해야합니다.

Maven 사용자는 pom.xml 파일에 다음 종속성을 추가 할 수 있습니다.

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

Gradle 사용자는 build.gradle 파일에 다음 종속성을 추가 할 수 있습니다.

compile('org.springframework.boot:spring-boot-starter-jdbc')

H2 데이터베이스에 연결

H2 데이터베이스를 연결하려면 빌드 구성 파일에 H2 데이터베이스 종속성을 추가해야합니다.

Maven 사용자의 경우 pom.xml 파일에 아래 종속성을 추가하십시오.

<dependency>
   <groupId>com.h2database</groupId>
   <artifactId>h2</artifactId>
</dependency>

Gradle 사용자의 경우 build.gradle 파일에 아래 종속성을 추가하십시오.

compile('com.h2database:h2')

H2 데이터베이스에 연결하려면 classpath src / main / resources 디렉터리에 schema.sql 파일과 data.sql 파일을 만들어야합니다.

schema.sql 파일은 다음과 같습니다.

CREATE TABLE PRODUCT (ID INT PRIMARY KEY, PRODUCT_NAME VARCHAR(25));

data.sql 파일은 다음과 같습니다.

INSERT INTO PRODUCT (ID,PRODUCT_NAME) VALUES (1,'Honey');
INSERT INTO PRODUCT (ID,PRODUCT_NAME) VALUES (2,'Almond');

MySQL 연결

MySQL 데이터베이스를 연결하려면 빌드 구성 파일에 MySQL 종속성을 추가해야합니다.

Maven 사용자의 경우 pom.xml 파일에 다음 종속성을 추가하십시오.

<dependency>
   <groupId>mysql</groupId>
   <artifactId>mysql-connector-java</artifactId>
</dependency>

Gradle 사용자의 경우 build.gradle 파일에 다음 종속성을 추가하십시오.

compile('mysql:mysql-connector-java')

이제 다음과 같이 MySQL에서 데이터베이스와 테이블을 만듭니다.

속성 파일 사용자의 경우 application.properties 파일에 다음 속성을 추가합니다.

spring.datasource.driverClassName = com.mysql.jdbc.Driver
spring.datasource.url = jdbc:mysql://localhost:3306/PRODUCTSERVICE?autoreconnect = true
spring.datasource.username = root
spring.datasource.password = root
spring.datasource.testOnBorrow = true
spring.datasource.testWhileIdle = true
spring.datasource.timeBetweenEvictionRunsMillis = 60000
spring.datasource.minEvictableIdleTimeMillis = 30000
spring.datasource.validationQuery = SELECT 1
spring.datasource.max-active = 15
spring.datasource.max-idle = 10
spring.datasource.max-wait = 8000

YAML 사용자의 경우 application.yml 파일에 다음 속성을 추가합니다.

spring:
   datasource: 
      driverClassName: com.mysql.jdbc.Driver
      url: "jdbc:mysql://localhost:3306/PRODUCTSERVICE?autoreconnect=true"
      username: "root"
      password: "root"
      testOnBorrow: true
      testWhileIdle: true
      timeBetweenEvictionRunsMillis: 60000
      minEvictableIdleTimeMillis: 30000
      validationQuery: SELECT 1
      max-active: 15
      max-idle: 10
      max-wait: 8000

Redis 연결

Redis는 인 메모리 데이터 구조를 저장하는 데 사용되는 오픈 소스 데이터베이스입니다. Spring Boot 애플리케이션에서 Redis 데이터베이스를 연결하려면 빌드 구성 파일에 Redis 종속성을 추가해야합니다.

Maven 사용자는 pom.xml 파일에 다음 종속성을 추가해야합니다.

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

Gradle 사용자는 build.gradle 파일에 다음 종속성을 추가해야합니다.

compile('org.springframework.boot:spring-boot-starter-data-redis')

Redis 연결의 경우 RedisTemplate을 사용해야합니다. RedisTemplate의 경우 JedisConnectionFactory 세부 정보를 제공해야합니다.

@Bean
JedisConnectionFactory jedisConnectionFactory() {
   JedisConnectionFactory jedisConFactory = new JedisConnectionFactory();
   jedisConFactory.setHostName("localhost");
   jedisConFactory.setPort(6000);
   jedisConFactory.setUsePool(true);
   return jedisConFactory;
}
@Bean
public RedisTemplate<String, Object> redisTemplate() {
   RedisTemplate<String, Object> template = new RedisTemplate<>();
   template.setConnectionFactory(jedisConnectionFactory());
   template.setKeySerializer(new StringRedisSerializer());
   template.setHashKeySerializer(new StringRedisSerializer());
   template.setHashValueSerializer(new StringRedisSerializer());
   template.setValueSerializer(new StringRedisSerializer());
   return template;
}

이제 RedisTemplate 클래스를 자동으로 연결하고 Redis 데이터베이스의 데이터에 액세스합니다.

@Autowired

RedisTemplate<String, Object> redis;
Map<Object,Object> datalist = redis.opsForHash().entries(“Redis_code_index_key”);

JDBC 템플릿

Spring Boot 애플리케이션에서 JdbcTemplate을 사용하여 관계형 데이터베이스에 액세스하려면 빌드 구성 파일에 Spring Boot Starter JDBC 종속성을 추가해야합니다.

그런 다음 JdbcTemplate 클래스를 @Autowired하면 Spring Boot는 자동으로 데이터베이스를 연결하고 JdbcTemplate 객체에 대한 데이터 소스를 설정합니다.

@Autowired
JdbcTemplate jdbcTemplate;
Collection<Map<String, Object>> rows = jdbc.queryForList("SELECT QUERY");

@Repository 주석을 클래스 파일에 추가해야합니다. @Repository 주석은 Spring Boot 애플리케이션을위한 데이터베이스 저장소를 만드는 데 사용됩니다.

@Repository
public class ProductServiceDAO {
}

다중 데이터 소스

단일 Spring Boot 애플리케이션에 'n'개의 데이터 소스를 유지할 수 있습니다. 여기에 제공된 예제는 Spring Boot 애플리케이션에서 둘 이상의 데이터 소스를 작성하는 방법을 보여줍니다. 이제 응용 프로그램 속성 파일에 두 개의 데이터 소스 구성 세부 정보를 추가합니다.

속성 파일 사용자의 경우 application.properties 파일에 다음 속성을 추가합니다.

spring.dbProductService.driverClassName = com.mysql.jdbc.Driver
spring.dbProductService.url = jdbc:mysql://localhost:3306/PRODUCTSERVICE?autoreconnect = true
spring.dbProductService.username = root
spring.dbProductService.password = root
spring.dbProductService.testOnBorrow = true
spring.dbProductService.testWhileIdle = true
spring.dbProductService.timeBetweenEvictionRunsMillis = 60000
spring.dbProductService.minEvictableIdleTimeMillis = 30000
spring.dbProductService.validationQuery = SELECT 1
spring.dbProductService.max-active = 15
spring.dbProductService.max-idle = 10
spring.dbProductService.max-wait = 8000

spring.dbUserService.driverClassName = com.mysql.jdbc.Driver
spring.dbUserService.url = jdbc:mysql://localhost:3306/USERSERVICE?autoreconnect = true
spring.dbUserService.username = root
spring.dbUserService.password = root
spring.dbUserService.testOnBorrow = true
spring.dbUserService.testWhileIdle = true
spring.dbUserService.timeBetweenEvictionRunsMillis = 60000
spring.dbUserService.minEvictableIdleTimeMillis = 30000
spring.dbUserService.validationQuery = SELECT 1
spring.dbUserService.max-active = 15
spring.dbUserService.max-idle = 10
spring.dbUserService.max-wait = 8000

Yaml 사용자는 application.yml 파일에 다음 속성을 추가해야합니다.

spring:
   dbProductService: 
      driverClassName: com.mysql.jdbc.Driver
      url: "jdbc:mysql://localhost:3306/PRODUCTSERVICE?autoreconnect=true"
      password: "root"
      username: "root"
      testOnBorrow: true
      testWhileIdle: true
      timeBetweenEvictionRunsMillis: 60000
      minEvictableIdleTimeMillis: 30000
      validationQuery: SELECT 1
      max-active: 15
      max-idle: 10
      max-wait: 8000
   dbUserService: 
      driverClassName: com.mysql.jdbc.Driver
      url: "jdbc:mysql://localhost:3306/USERSERVICE?autoreconnect=true"
      password: "root"
      username: "root"
      testOnBorrow: true
      testWhileIdle: true
      timeBetweenEvictionRunsMillis: 60000
      minEvictableIdleTimeMillis: 30000
      validationQuery: SELECT 1    
      max-active: 15
      max-idle: 10
      max-wait: 8000

이제 Configuration 클래스를 만들어 여러 데이터 소스에 대한 DataSource 및 JdbcTemplate을 만듭니다.

import javax.sql.DataSource;

import org.springframework.beans.factory.annotation.Autowired;
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 DatabaseConfig {
   @Bean(name = "dbProductService")
   @ConfigurationProperties(prefix = "spring.dbProductService")
   @Primary
   public DataSource createProductServiceDataSource() {
      return DataSourceBuilder.create().build();
   }
   @Bean(name = "dbUserService")
   @ConfigurationProperties(prefix = "spring.dbUserService")
   public DataSource createUserServiceDataSource() {
      return DataSourceBuilder.create().build();
   }
   @Bean(name = "jdbcProductService")
   @Autowired
   public JdbcTemplate createJdbcTemplate_ProductService(@Qualifier("dbProductService") DataSource productServiceDS) {
      return new JdbcTemplate(productServiceDS);
   }
   @Bean(name = "jdbcUserService")
   @Autowired
   public JdbcTemplate createJdbcTemplate_UserService(@Qualifier("dbUserService") DataSource userServiceDS) {
      return new JdbcTemplate(userServiceDS);
   }
}

그런 다음 @Qualifier 주석을 사용하여 JDBCTemplate 객체를 자동 연결합니다.

@Qualifier("jdbcProductService")
@Autowired
JdbcTemplate jdbcTemplate;

@Qualifier("jdbcUserService")
@Autowired
JdbcTemplate jdbcTemplate;