स्प्रिंग बूट - डेटाबेस हैंडलिंग

स्प्रिंग बूट डेटाबेस के लिए एक डेटा स्रोत बनाने के लिए एक बहुत अच्छा समर्थन प्रदान करता है। स्प्रिंग बूट में डेटा स्रोत बनाने के लिए हमें कोई अतिरिक्त कोड लिखने की आवश्यकता नहीं है। बस निर्भरता को जोड़ना और कॉन्फ़िगरेशन विवरण करना डेटा स्रोत बनाने और डेटाबेस को जोड़ने के लिए पर्याप्त है।

इस अध्याय में, हम डेटाबेस को जोड़ने के लिए स्प्रिंग बूट JDBC ड्राइवर कनेक्शन का उपयोग करने जा रहे हैं।

सबसे पहले, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट स्टार्टर JDBC निर्भरता जोड़ने की आवश्यकता है।

Maven उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरताएँ जोड़ सकते हैं।

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

ग्रेडल उपयोगकर्ता बिल्ड.ग्रेड फ़ाइल में निम्न निर्भरताएँ जोड़ सकते हैं।

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

H2 डेटाबेस से कनेक्ट करें

H2 डेटाबेस को जोड़ने के लिए, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में H2 डेटाबेस निर्भरता को जोड़ना होगा।

मावेन उपयोगकर्ताओं के लिए, अपनी pom.xml फ़ाइल में नीचे की निर्भरता जोड़ें।

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

ग्रेडल उपयोगकर्ताओं के लिए, अपनी build.gradle फ़ाइल में नीचे की निर्भरता जोड़ें।

compile('com.h2database:h2')

हमें H2 डेटाबेस को जोड़ने के लिए classpath src / main / Resources डायरेक्टरी के तहत स्कीमा.एसक्यूएल फाइल और data.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 निर्भरता को जोड़ना होगा।

मावेन उपयोगकर्ताओं के लिए, अपनी pom.xml फ़ाइल में निम्न निर्भरता जोड़ें।

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

ग्रेडल उपयोगकर्ताओं के लिए, अपनी 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

रेडिस कनेक्ट करें

रेडिस एक खुला स्रोत डेटाबेस है जिसका उपयोग इन-मेमोरी डेटा संरचना को संग्रहीत करने के लिए किया जाता है। स्प्रिंग बूट एप्लिकेशन में रेडिस डेटाबेस को जोड़ने के लिए, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में रेडिस निर्भरता को जोड़ना होगा।

Maven उपयोगकर्ताओं को आपकी pom.xml फ़ाइल में निम्न निर्भरता जोड़नी चाहिए।

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

ग्रेड उपयोगकर्ता को आपकी बिल्ड.ग्रेड फ़ाइल में निम्न निर्भरता जोड़नी चाहिए।

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”);

JDBCTemplate

स्प्रिंग बूट एप्लिकेशन में JdbcTemplate का उपयोग करके रिलेशनल डेटाबेस तक पहुंचने के लिए, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग बूट स्टार्टर JDBC निर्भरता जोड़ने की आवश्यकता है।

फिर, यदि आपने JdbcTemplate वर्ग को @Autowired किया है, तो स्प्रिंग बूट स्वचालित रूप से डेटाबेस को जोड़ता है और JdbcTemplate ऑब्जेक्ट के लिए डेटा स्रोत सेट करता है।

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

@ रिपॉजिटरी एनोटेशन को क्लास फाइल में जोड़ा जाना चाहिए। @Repository एनोटेशन का उपयोग आपके स्प्रिंग बूट एप्लिकेशन के लिए डेटाबेस रिपॉजिटरी बनाने के लिए किया जाता है।

@Repository
public class ProductServiceDAO {
}

एकाधिक डेटा स्रोत

हम एकल स्प्रिंग बूट एप्लिकेशन में 'n' संख्या डेटा स्रोत रख सकते हैं। यहां दिए गए उदाहरण से पता चलता है कि स्प्रिंग बूट एप्लिकेशन में 1 से अधिक डेटा स्रोत कैसे बनाएं। अब, एप्लिकेशन गुण फ़ाइल में दो डेटा स्रोत कॉन्फ़िगरेशन विवरण जोड़ें।

गुण फ़ाइल उपयोगकर्ताओं के लिए, निम्न गुणों को अपने 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

यमल उपयोगकर्ताओं को आपके एप्लिकेशन में निम्नलिखित गुण जोड़ना चाहिए।

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

अब, कई डेटा स्रोतों के लिए डेटा स्रोत और 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;