Skip to content

Commit e4ef2fe

Browse files
committed
Spring Boot 2.x基础教程:默认数据源Hikari的配置详解
1 parent f05d815 commit e4ef2fe

File tree

11 files changed

+325
-0
lines changed

11 files changed

+325
-0
lines changed

2.1.x/README.md

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -68,7 +68,22 @@
6868
### 数据访问
6969

7070
- [Spring Boot 2.x基础教程:使用JdbcTemplate访问MySQL数据库](http://blog.didispace.com/spring-boot-learning-21-3-1/)
71+
- [Spring Boot 2.x基础教程:默认数据源Hikari的配置详解](http://blog.didispace.com/spring-boot-learning-21-3-2/)
7172

73+
连载中...Star关注支持以下,随时获得更新信息!
74+
75+
- [Spring Boot 2.x基础教程:国产数据库连接池Druid使用详解]
76+
- [Spring Boot 2.x基础教程:使用Spring Data JPA]
77+
- [Spring Boot 2.x基础教程:使用MyBatis]
78+
- [Spring Boot 2.x基础教程:多数据源配置]
79+
- [Spring Boot 2.x基础教程:数据库管理Flyway]
80+
81+
**其他数据存储**
82+
83+
- [Spring Boot 2.x基础教程:使用Redis]
84+
- [Spring Boot 2.x基础教程:使用MongoDB]
85+
- [Spring Boot 2.x基础教程:使用ElasticSearch]
86+
- [Spring Boot 2.x基础教程:使用LDAP]
7287

7388
连载中...Star关注支持以下,随时获得更新信息!
7489

2.1.x/README_zh.md

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -60,10 +60,28 @@
6060

6161
### 数据访问
6262

63+
**关系型数据库**
64+
6365
- [Spring Boot 2.x基础教程:使用JdbcTemplate访问MySQL数据库](http://blog.didispace.com/spring-boot-learning-21-3-1/)
66+
- [Spring Boot 2.x基础教程:默认数据源Hikari的配置详解](http://blog.didispace.com/spring-boot-learning-21-3-2/)
6467

6568
连载中...Star关注支持以下,随时获得更新信息!
6669

70+
- [Spring Boot 2.x基础教程:Druid数据源配置详解]
71+
- [Spring Boot 2.x基础教程:使用Spring Data JPA]
72+
- [Spring Boot 2.x基础教程:使用MyBatis]
73+
- [Spring Boot 2.x基础教程:多数据源配置]
74+
- [Spring Boot 2.x基础教程:数据库管理Flyway]
75+
76+
**其他数据存储**
77+
78+
- [Spring Boot 2.x基础教程:使用Redis]
79+
- [Spring Boot 2.x基础教程:使用MongoDB]
80+
- [Spring Boot 2.x基础教程:使用ElasticSearch]
81+
- [Spring Boot 2.x基础教程:使用LDAP]
82+
83+
84+
6785
### 1.x到2.x
6886

6987
- [Spring Boot 2.0 正式发布,升还是不升呢?](http://blog.didispace.com/spring-boot-2-release/)

2.1.x/chapter3-2/.gitignore

Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
HELP.md
2+
/target/
3+
!.mvn/wrapper/maven-wrapper.jar
4+
5+
### STS ###
6+
.apt_generated
7+
.classpath
8+
.factorypath
9+
.project
10+
.settings
11+
.springBeans
12+
.sts4-cache
13+
14+
### IntelliJ IDEA ###
15+
.idea
16+
*.iws
17+
*.iml
18+
*.ipr
19+
20+
### NetBeans ###
21+
/nbproject/private/
22+
/nbbuild/
23+
/dist/
24+
/nbdist/
25+
/.nb-gradle/
26+
/build/
27+
28+
### VS Code ###
29+
.vscode/

2.1.x/chapter3-2/pom.xml

Lines changed: 58 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,58 @@
1+
<?xml version="1.0" encoding="UTF-8"?>
2+
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
3+
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
4+
<modelVersion>4.0.0</modelVersion>
5+
6+
<parent>
7+
<groupId>org.springframework.boot</groupId>
8+
<artifactId>spring-boot-starter-parent</artifactId>
9+
<version>2.1.3.RELEASE</version>
10+
<relativePath/> <!-- lookup parent from repository -->
11+
</parent>
12+
13+
<groupId>com.didispace</groupId>
14+
<artifactId>chapter3-2</artifactId>
15+
<version>0.0.1-SNAPSHOT</version>
16+
17+
<properties>
18+
<java.version>1.8</java.version>
19+
</properties>
20+
21+
<dependencies>
22+
<dependency>
23+
<groupId>org.springframework.boot</groupId>
24+
<artifactId>spring-boot-starter-web</artifactId>
25+
</dependency>
26+
27+
<dependency>
28+
<groupId>org.springframework.boot</groupId>
29+
<artifactId>spring-boot-starter-jdbc</artifactId>
30+
</dependency>
31+
32+
<dependency>
33+
<groupId>mysql</groupId>
34+
<artifactId>mysql-connector-java</artifactId>
35+
</dependency>
36+
37+
<dependency>
38+
<groupId>org.projectlombok</groupId>
39+
<artifactId>lombok</artifactId>
40+
</dependency>
41+
42+
<dependency>
43+
<groupId>org.springframework.boot</groupId>
44+
<artifactId>spring-boot-starter-test</artifactId>
45+
<scope>test</scope>
46+
</dependency>
47+
</dependencies>
48+
49+
<build>
50+
<plugins>
51+
<plugin>
52+
<groupId>org.springframework.boot</groupId>
53+
<artifactId>spring-boot-maven-plugin</artifactId>
54+
</plugin>
55+
</plugins>
56+
</build>
57+
58+
</project>
Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
package com.didispace.chapter32;
2+
3+
import org.springframework.boot.SpringApplication;
4+
import org.springframework.boot.autoconfigure.SpringBootApplication;
5+
6+
@SpringBootApplication
7+
public class Chapter32Application {
8+
9+
public static void main(String[] args) {
10+
SpringApplication.run(Chapter32Application.class, args);
11+
}
12+
13+
}
Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
package com.didispace.chapter32;
2+
3+
import lombok.Data;
4+
import lombok.NoArgsConstructor;
5+
6+
@Data
7+
@NoArgsConstructor
8+
public class User {
9+
10+
private String name;
11+
private Integer age;
12+
13+
}
Lines changed: 40 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
package com.didispace.chapter32;
2+
3+
import java.util.List;
4+
5+
public interface UserService {
6+
7+
/**
8+
* 新增一个用户
9+
*
10+
* @param name
11+
* @param age
12+
*/
13+
int create(String name, Integer age);
14+
15+
/**
16+
* 根据name查询用户
17+
*
18+
* @param name
19+
* @return
20+
*/
21+
List<User> getByName(String name);
22+
23+
/**
24+
* 根据name删除用户
25+
*
26+
* @param name
27+
*/
28+
int deleteByName(String name);
29+
30+
/**
31+
* 获取用户总量
32+
*/
33+
int getAllUsers();
34+
35+
/**
36+
* 删除所有用户
37+
*/
38+
int deleteAllUsers();
39+
40+
}
Lines changed: 52 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,52 @@
1+
package com.didispace.chapter32;
2+
3+
import org.springframework.beans.factory.annotation.Autowired;
4+
import org.springframework.jdbc.core.JdbcTemplate;
5+
import org.springframework.jdbc.core.RowMapper;
6+
import org.springframework.stereotype.Service;
7+
8+
import java.sql.ResultSet;
9+
import java.sql.SQLException;
10+
import java.util.List;
11+
12+
@Service
13+
public class UserServiceImpl implements UserService {
14+
15+
private JdbcTemplate jdbcTemplate;
16+
17+
UserServiceImpl(JdbcTemplate jdbcTemplate) {
18+
this.jdbcTemplate = jdbcTemplate;
19+
}
20+
21+
@Override
22+
public int create(String name, Integer age) {
23+
return jdbcTemplate.update("insert into USER(NAME, AGE) values(?, ?)", name, age);
24+
}
25+
26+
@Override
27+
public List<User> getByName(String name) {
28+
List<User> users = jdbcTemplate.query("select NAME, AGE from USER where NAME = ?", (resultSet, i) -> {
29+
User user = new User();
30+
user.setName(resultSet.getString("NAME"));
31+
user.setAge(resultSet.getInt("AGE"));
32+
return user;
33+
}, name);
34+
return users;
35+
}
36+
37+
@Override
38+
public int deleteByName(String name) {
39+
return jdbcTemplate.update("delete from USER where NAME = ?", name);
40+
}
41+
42+
@Override
43+
public int getAllUsers() {
44+
return jdbcTemplate.queryForObject("select count(1) from USER", Integer.class);
45+
}
46+
47+
@Override
48+
public int deleteAllUsers() {
49+
return jdbcTemplate.update("delete from USER");
50+
}
51+
52+
}
Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
spring.datasource.url=jdbc:mysql://localhost:3306/test
2+
spring.datasource.username=root
3+
spring.datasource.password=
4+
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
5+
6+
# 最小空闲连接,默认值10,小于0或大于maximum-pool-size,都会重置为maximum-pool-size
7+
spring.datasource.hikari.minimum-idle=10
8+
# 最大连接数,小于等于0会被重置为默认值10;大于零小于1会被重置为minimum-idle的值
9+
spring.datasource.hikari.maximum-pool-size=20
10+
# 空闲连接超时时间,默认值600000(10分钟),大于等于max-lifetime且max-lifetime>0,会被重置为0;不等于0且小于10秒,会被重置为10秒。
11+
spring.datasource.hikari.idle-timeout=500000
12+
# 连接最大存活时间.不等于0且小于30秒,会被重置为默认值30分钟.设置应该比mysql设置的超时时间短
13+
spring.datasource.hikari.max-lifetime=540000
14+
# 连接超时时间:毫秒,小于250毫秒,否则被重置为默认值30秒
15+
spring.datasource.hikari.connection-timeout=60000
16+
# 用于测试连接是否可用的查询语句
17+
spring.datasource.hikari.connection-test-query=SELECT 1
Lines changed: 69 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,69 @@
1+
package com.didispace.chapter32;
2+
3+
import lombok.extern.slf4j.Slf4j;
4+
import org.junit.Assert;
5+
import org.junit.Before;
6+
import org.junit.Test;
7+
import org.junit.runner.RunWith;
8+
import org.springframework.beans.factory.annotation.Autowired;
9+
import org.springframework.boot.test.context.SpringBootTest;
10+
import org.springframework.http.MediaType;
11+
import org.springframework.test.annotation.Rollback;
12+
import org.springframework.test.context.junit4.SpringRunner;
13+
import org.springframework.test.web.servlet.MockMvc;
14+
import org.springframework.test.web.servlet.RequestBuilder;
15+
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
16+
import org.springframework.transaction.annotation.Transactional;
17+
18+
import javax.sql.DataSource;
19+
import java.util.List;
20+
21+
import static org.hamcrest.Matchers.equalTo;
22+
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.*;
23+
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
24+
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
25+
26+
@Slf4j
27+
@RunWith(SpringRunner.class)
28+
@SpringBootTest
29+
public class Chapter32ApplicationTests {
30+
31+
@Autowired
32+
private UserService userSerivce;
33+
34+
@Autowired
35+
private DataSource dataSource;
36+
37+
@Before
38+
public void setUp() {
39+
// 准备,清空user表
40+
userSerivce.deleteAllUsers();
41+
42+
}
43+
44+
@Test
45+
public void test() throws Exception {
46+
// 插入5个用户
47+
userSerivce.create("Tom", 10);
48+
userSerivce.create("Mike", 11);
49+
userSerivce.create("Didispace", 30);
50+
userSerivce.create("Oscar", 21);
51+
userSerivce.create("Linda", 17);
52+
53+
// 查询名为Oscar的用户,判断年龄是否匹配
54+
List<User> userList = userSerivce.getByName("Oscar");
55+
Assert.assertEquals(21, userList.get(0).getAge().intValue());
56+
57+
// 查数据库,应该有5个用户
58+
Assert.assertEquals(5, userSerivce.getAllUsers());
59+
60+
// 删除两个用户
61+
userSerivce.deleteByName("Tom");
62+
userSerivce.deleteByName("Mike");
63+
64+
// 查数据库,应该有5个用户
65+
Assert.assertEquals(3, userSerivce.getAllUsers());
66+
67+
}
68+
69+
}

0 commit comments

Comments
 (0)