स्प्रिंग बूट - डेटाबेस हैंडलिंग
स्प्रिंग बूट डेटाबेस के लिए एक डेटा स्रोत बनाने के लिए एक बहुत अच्छा समर्थन प्रदान करता है। स्प्रिंग बूट में डेटा स्रोत बनाने के लिए हमें कोई अतिरिक्त कोड लिखने की आवश्यकता नहीं है। बस निर्भरता को जोड़ना और कॉन्फ़िगरेशन विवरण करना डेटा स्रोत बनाने और डेटाबेस को जोड़ने के लिए पर्याप्त है।
इस अध्याय में, हम डेटाबेस को जोड़ने के लिए स्प्रिंग बूट 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;