一、集成 MySQL 数据库

1.1 配置 MySQL

添加依赖

<dependencies>
<!--Spring 数据库相关依赖-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<!--mysql 驱动依赖-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
</dependencies>

设置配置文件

spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/test?characterEncoding=utf8
username: root
password: sa000

1.2 测试数据库连接

添加测试依赖

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

test/java 目录下新建测试类

@SpringBootTest
public class DataBaseTest { @Autowired
private DataSource dataSource; @Test
public void testConnection() {
try {
Connection connection = dataSource.getConnection();
Assert.assertNotNull(connection);
} catch (SQLException e) {
fail("数据库连接获取失败,错误原因:" + e);
}
}
}

执行测试,发现绿条说明测试通过。

1.3 设置连接池

SpringBoot 在我们引入 spring-boot-starter-jdbcspring-boot-starter-data-jpa 依赖后就会默认启用连接池功能,它的连接池默认创建选择规则如下:

  • 优先寻找创建 HikariCP 连接池

  • 如果没有 HikariCP 连接池,会查找创建 Tomcat

  • 如果没有 Tomcat 连接池,会查找创建 dbcp

  • 如果没有 dbcp 连接池,会查找创建 dbcp2

  • 也可以使用 spring.datasource.type 属性指定连接池类型

    spring.datasource.type= com.zaxxer.hikari.HikariDataSource

我们来通过一个测试方法验证下:

@SpringBootTest
public class DataBaseTest { @Autowired
private DataSource dataSource; @Test
public void testDataSourceType(){
Assert.assertEquals(HikariDataSource.class,dataSource.getClass());
}
}

执行测试,发现绿条说明测试通过。

常用连接池配置如下:

#验证连接的有效性
spring.datasource.primary.test-while-idle=true
#获取连接时候验证,会影响性能
spring.datasource.primary.test-on-borrow=false
#在连接归还到连接池时是否测试该连接
spring.datasource.primary.test-on-return=false
spring.datasource.primary.validation-query=SELECT 1 FROM DUAL
#空闲连接回收的时间间隔,与test-while-idle一起使用,设置5分钟
spring.datasource.primary.time-between-eviction-runs-millis=300000
#连接池空闲连接的有效时间 ,设置30分钟
spring.datasource.primary.min-evictable-idle-time-millis=1800000
spring.datasource.primary.initial-size=5
#指定连接池中最大的活跃连接数.
spring.datasource.primary.max-active=50
#指定连接池等待连接返回的最大等待时间,毫秒单位.
spring.datasource.primary.max-wait=60000
#指定必须保持连接的最小值
spring.datasource.primary.min-idle=5

更多配置请参考 SprignBoot文档

1.4 JDBC 使用

配置好数据库之后,我们就来使用一下最基本的数据库操作。

在数据库 test 新建一个用户表:

CREATE TABLE `sys_user` (
`user_id` int(21) NOT NULL COMMENT '用户编码',
`user_name` varchar(50) DEFAULT NULL COMMENT '用户名',
`age` int(3) DEFAULT NULL COMMENT '年龄',
`email` varchar(100) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`user_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

test/java 目录下新建测试类

@SpringBootTest
public class JdbcTest {
@Autowired
private JdbcTemplate jdbcTemplate; @Test
public void test() {
delete();
Assert.assertEquals(0,count());
add();
Assert.assertEquals(1,count());
} private int count() {
String sql = "select count(user_id) from sys_user ";
Integer result = jdbcTemplate.queryForObject(sql, Integer.class);
return result;
} private void add() {
String sql = "insert into sys_user " +
"values('1','marklogzhu','26','marklogzhu@163.com')";
jdbcTemplate.execute(sql);
} private void delete() {
String sql = "delete from sys_user ";
jdbcTemplate.execute(sql);
} }

执行测试,发现绿条说明测试通过。

二、集成 Redis 数据库

2.1 配置 Redis

添加依赖

<dependencies>
......
<!--Spring redis 依赖-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!--redis 连接池依赖-->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
<version>2.7.0</version>
</dependency>
</dependencies>

设置配置文件

spring:
redis:
host: 127.0.0.1
port: 6379
# 连接超时时间
timeout: 1000ms
jedis:
pool:
# 最大连接数
max-active: 8
# 最大阻塞等待时间(负数表示没限制)
max-wait: -1ms
# 最大空闲
max-idle: 8
# 最小空闲
min-idle: 0

测试

@SpringBootTest
public class RedisTest { @Autowired
private StringRedisTemplate stringRedisTemplate; @Test
public void testSimpleValue(){
String key = "name";
String name ="MarkLogZhu";
stringRedisTemplate.opsForValue().set(key,name);
String result = stringRedisTemplate.opsForValue().get(key);
Assert.assertEquals(name,result);
} }

执行测试,发现绿条说明测试通过。

2.2 实现序列化功能

添加依赖

<dependencies>
......
<!--JSON工具类依赖-->
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<version>2.8.6</version>
</dependency>
</dependencies>

设置序列化功能

@Configuration
public class RedisConfig { @Bean
@ConditionalOnMissingBean(name = "redisTemplate")
public RedisTemplate<Object, Object> redisTemplate(
RedisConnectionFactory redisConnectionFactory) {
RedisTemplate<Object, Object> redisTemplate = new RedisTemplate<>();
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setHashKeySerializer(jackson2JsonRedisSerializer());
redisTemplate.setValueSerializer(jackson2JsonRedisSerializer());
redisTemplate.setConnectionFactory(redisConnectionFactory);
redisTemplate.afterPropertiesSet();
return redisTemplate;
} @SuppressWarnings({"unchecked", "rawtypes"})
@Bean
public Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer() {
final Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(
Object.class);
final ObjectMapper objectMapper = Jackson2ObjectMapperBuilder.json().build();
objectMapper.disable(DeserializationFeature.FAIL_ON_IGNORED_PROPERTIES);
objectMapper.disable(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES);
objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
jackson2JsonRedisSerializer.setObjectMapper(objectMapper);
return jackson2JsonRedisSerializer;
} }

测试

@SpringBootTest
public class RedisTest { @Autowired
private RedisTemplate redisTemplate; @Test
public void testObjectValue(){
String key = "obj";
SysUser user = new SysUser(1,"MarkLogZhu");
redisTemplate.opsForValue().set(key,user);
SysUser result = (SysUser)redisTemplate.opsForValue().get(key);
Assert.assertEquals(user,result);
} }

执行测试,发现绿条说明测试通过。

SpringBoot之集成数据库的更多相关文章

  1. springboot elasticsearch 集成注意事项

    文章来源: http://www.cnblogs.com/guozp/p/8686904.html 一 elasticsearch基础 这里假设各位已经简单了解过elasticsearch,并不对es ...

  2. SpringBoot使用Druid数据库加密链接完整方案

    网上的坑 springboot 使用 Druid 数据库加密链接方案,不建议采用网上的一篇文章<springboot 结合 Druid 加密数据库密码遇到的坑!>介绍的方式来进行加密链接实 ...

  3. SpringBoot项目集成PageHelper使用

    SpringBoot项目集成PageHelper使用 一.开始 ​ 地址:https://github.com/pagehelper/Mybatis-PageHelper ​ 在spring boot ...

  4. 在springboot中集成mybatis开发

    在springboot中利用mybatis框架进行开发需要集成mybatis才能进行开发,那么如何在springboot中集成mybatis呢?按照以下几个步骤就可以实现springboot集成myb ...

  5. springboot中集成memcached

    前言 Memcached 是一个高性能的分布式内存对象缓存系统,其存储性能在某些方面不比redis差,甚至在文本类型数据的存储上性能略优于redis,本文将介绍如何在springboot中集成memc ...

  6. Neo4j在linux上的安装与Springboot的集成

    Neo4j在linux上的安装与Springboot的集成 在linux安装: 前提:安装配置好java环境 1.下载neo4j 官方社区版下载地址:https://neo4j.com/downloa ...

  7. FMDB 二次封装工具类,让你快速学会封装,集成数据库

    来源:StrivEver 链接:http://www.jianshu.com/p/4c77aee0b41c 上个版本为了增加用户体验,部分页面集成了离线缓存数据功能,于是就在项目里使用了数据库管理离线 ...

  8. Springboot Application 集成 OSGI 框架开发

    内容来源:https://www.ibm.com/developerworks/cn/java/j-springboot-application-integrated-osgi-framework-d ...

  9. SpringBoot项目集成Hystrix

    Hystrix Hystrix是由Netflix开源的一个服务隔离组件,通过服务隔离来避免由于依赖延迟.异常,引起资源耗尽导致系统不可用的解决方案. 1.什么是服务熔断   服务熔断就是对该服务的调用 ...

随机推荐

  1. 使用discriminator实现鉴别器

    1在人员接口实现方法 public Employee getEmpByIdStep(Integer id); 2在映射文件进行配置 <!-- public Employee getEmpById ...

  2. 异步 map 和模块打包

    概述 本文是我在查资料的时候学到的一些东西,记录下来,供以后开发时参考,相信对其他人也有用. 参考资料: 异步函数 - 提高 Promise 的易用性 深入 CommonJs 与 ES6 Module ...

  3. IntToHex

    IntToHex是一种函数,功能是将一个值转换成16进制形式的字符串. IntToHex(int Value, int Digits) 来源: 在Delphi.Pascal或C++ Builder中使 ...

  4. 关于OPC连接读写下位机PLC(转)

    原文转自:http://blog.csdn.net/u012252959/article/details/49736285?locationNum=11 开发OPC客户端程序时,首先应该生成OPC服务 ...

  5. zimg 服务器配置文件

    --zimg server config --server config --是否后台运行 is_daemon = --绑定IP ip = '0.0.0.0' --端口 port = --运行线程数, ...

  6. 利用coverage工具进行Python代码覆盖率测试

    Coverage是一种用于统计Python代码覆盖率的工具,通过它可以检测测试代码对被测代码的覆盖率情况. Coverage安装 1.安装命令:pip install coverage 2.查看cov ...

  7. 杭州集训Day5

    下面是Day5的题目!(其实都咕了好几天了 100+70+40=210. T1 皇后 XY 的疑难 (1s 512MB) 1.1 题目描述 有一个n*n的王国城堡地图上,皇后XY喜欢看骑士之间的战斗, ...

  8. Java Mail 附件名太长导致接收端附件名解析出错

    问题前提:公司需要往邮件中写 excle 文件,返送成功后发现文件格式有误(如:xxxx.bat 等文件后缀),但是有些文件又不会, 后来发现是由于文件名称太长所导致. 问题原因:java mail中 ...

  9. P5016龙虎斗

    这道题是2018年普及组的第二题,是一个模拟题. 首先计算出双方各自的势力,然后将增援的队伍势力加上,比较此时双方势力,并且作差,最后枚举将公平兵加在哪一个兵营.看似简单的题被我20分钟就写完了,但是 ...

  10. 分布式均匀算法--hash性一致算法--hash slot(转)

    目录 1.redis cluster介绍 2.最老土的hash算法和弊端(大量缓存重建) 3.一致性hash算法(自动缓存迁移)+虚拟节点(自动负载均衡) 不用遍历    -->   hash算 ...