SpringBoot3数据库集成

打印 上一主题 下一主题

主题 876|帖子 876|积分 2628

标签:Jdbc.Druid.Mybatis.Plus;
一、简介

项目工程中,集成数据库实现对数据的增晒改查管理,是最基础的能力,而对于这个功能的实现,其组件选型也非常丰富;
通过如下几个组件来实现数据库的整合;
Druid连接池:阿里开源的数据库连接池,并且提供SQL执行的监控能力;
MybatisPlus框架:基于Mybatis框架的增强工具包,可以用于简化持久层开发,显著的提高效率;
MySQL数据库:常用的关系型数据库组件,在案例中使用Druid组件来连接数据库;
二、工程搭建

1、工程结构


2、依赖管理

Druid连接池使用的是1.2.18版本;在mybatis-plus组件中依赖mybatis框架的3.5.10版本;MySQL本地环境是5.7版本,这里依赖包使用8.0.19版本;
  1. <dependency>
  2.     <groupId>mysql</groupId>
  3.     <artifactId>mysql-connector-java</artifactId>
  4.     <version>${mysql.version}</version>
  5. </dependency>
  6. <dependency>
  7.     <groupId>com.alibaba</groupId>
  8.     <artifactId>druid-spring-boot-3-starter</artifactId>
  9.     <version>${druid-spring-boot.version}</version>
  10. </dependency>
  11. <dependency>
  12.     <groupId>org.springframework.boot</groupId>
  13.     <artifactId>spring-boot-starter-jdbc</artifactId>
  14.     <version>${spring-boot.version}</version>
  15. </dependency>
  16. <dependency>
  17.     <groupId>com.baomidou</groupId>
  18.     <artifactId>mybatis-plus-boot-starter</artifactId>
  19.     <version>${mybatis-plus.version}</version>
  20. </dependency>
复制代码
三、Druid连接池

1、配置文件

有关于Druid连接池的可配置参数还有很多,可以参考源码中的描述或者官方案例,此处只提供部分常见的参数配置;
  1. spring:
  2.   datasource:
  3.     type: com.alibaba.druid.pool.DruidDataSource
  4.     druid:
  5.       # 数据库
  6.       url: jdbc:mysql://localhost:3306/boot-jdbc
  7.       username: root
  8.       password: 123456
  9.       driver-class-name: com.mysql.cj.jdbc.Driver
  10.       # 连接池-初始化大小
  11.       initial-size: 10
  12.       # 连接池-最大连接数
  13.       max-active: 100
  14.       # 最大等待时间
  15.       max-wait: 60000
  16.       # 连接池-最小空闲数
  17.       min-idle: 10
  18.       # 检测空闲连接
  19.       test-while-idle: true
  20.       # 最小空闲时间
  21.       min-evictable-idle-time-millis: 300000
复制代码
1.2 配置类

配置两个Bean对象,分别DruidDataSource类和JdbcTemplate类;
  1. @Configuration
  2. public class DruidConfig {
  3.     @Bean("dataSource")
  4.     @ConfigurationProperties(prefix = "spring.datasource.druid")
  5.     public DruidDataSource dataSource() {
  6.         return new DruidDataSource();
  7.     }
  8.     @Bean("jdbcTemplate")
  9.     public JdbcTemplate jdbcTemplate() {
  10.         return new JdbcTemplate(dataSource());
  11.     }
  12. }
复制代码
四、JDBC操作

1、数据库表

在boot-jdbc数据库中添加两张测试表,用户基础信息tb_user表和用户扩展信息tb_user_extd表,脚本文件在工程的resources/sql-script目录下;
  1. CREATE TABLE `tb_user` (
  2.   `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  3.   `user_name` varchar(30) NOT NULL COMMENT '用户名称',
  4.   `email` varchar(50) DEFAULT NULL COMMENT '邮件',
  5.   `phone` varchar(20) NOT NULL COMMENT '手机号',
  6.   `create_time` datetime DEFAULT NULL COMMENT '创建时间',
  7.   `update_time` datetime DEFAULT NULL COMMENT '更新时间',
  8.   `state` int(1) DEFAULT '1' COMMENT '状态:1启用,2删除',
  9.   PRIMARY KEY (`id`)
  10. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户基础信息';
  11. CREATE TABLE `tb_user_extd` (
  12.   `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  13.   `user_id` int(11) NOT NULL COMMENT '用户ID',
  14.   `city_name` varchar(50) DEFAULT NULL COMMENT '城市名称',
  15.   `school` varchar(200) DEFAULT NULL COMMENT '学校名称',
  16.   PRIMARY KEY (`id`),
  17.   KEY `user_id_index` (`user_id`)
  18. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户扩展信息';
复制代码
2、JdbcTemplate

JdbcTemplate是由spring-jdbc组件提供,支持DataSource的注册,是对数据库操作的深层封装,支持一系列数据操作方法;
  1. @Service
  2. public class JdbcService {
  3.     private static final Logger logger = LoggerFactory.getLogger(JdbcService.class);
  4.     @Resource
  5.     private JdbcTemplate jdbcTemplate ;
  6.     /**
  7.      * 添加数据
  8.      */
  9.     public int addData (User user){
  10.         return jdbcTemplate.update(
  11.                 "INSERT INTO `tb_user` (`user_name`, `email`, `phone`, `create_time`, `update_time`) VALUES (?, ?, ?, ?, ?)",
  12.                 user.getUserName(),user.getEmail(),user.getPhone(),user.getCreateTime(),user.getUpdateTime());
  13.     }
  14.     /**
  15.      * 查询全部
  16.      */
  17.     public List<User> queryAll (){
  18.         return jdbcTemplate.query("SELECT * FROM tb_user WHERE state=1",new BeanPropertyRowMapper<>(User.class));
  19.     }
  20.     /**
  21.      * 修改字段
  22.      */
  23.     public int updateName (Integer id,String name){
  24.         return jdbcTemplate.update("UPDATE `tb_user` SET `user_name` = ? WHERE `id` = ?",name,id);
  25.     }
  26.     /**
  27.      * 主键删除
  28.      */
  29.     public int deleteId (Integer id){
  30.         return jdbcTemplate.update("DELETE FROM `tb_user` WHERE `id` = ?",id);
  31.     }
  32. }
复制代码
五、MybatisPlus框架

1、配置管理

1.1 配置类
在配置类中,添加MapperScan注解用来扫描和注册MyBatis框架的mapper接口,以及设置PaginationInnerInterceptor分页拦截器;
  1. @Configuration
  2. @MapperScan("com.boot.jdbc.mapper")
  3. public class MybatisConfig {
  4.     /**
  5.      * 分页
  6.      */
  7.     @Bean
  8.     public MybatisPlusInterceptor paginationInterceptor() {
  9.         MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
  10.         interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
  11.         return interceptor;
  12.     }
  13. }
复制代码
1.2 配置文件
在日志中输出mybatis框架解析的SQL语句,方便在测试的时候快速发现问题;
  1. mybatis-plus:
  2.   configuration:
  3.     log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
复制代码
2、Mapper

Mapper接口编写数据库操作方法,Mapper.xml文件中定义数据库执行的SQL语句,在mybatis-plus组件中提供很多单表操作的默认方法实现,也可以自定义方法;
2.1 Mapper接口
  1. public interface UserMapper extends BaseMapper<User> {
  2.     /**
  3.      * 自定义分页
  4.      */
  5.     IPage<UserModel> queryUserPage(@Param("page") IPage<User> page);
  6. }
复制代码
2.2 Mapper文件
  1. <mapper namespace="com.boot.jdbc.mapper.UserMapper">
  2.     <select id="queryUserPage" resultType="com.boot.jdbc.entity.UserModel">
  3.         SELECT
  4.             tb1.id userId,
  5.             tb1.user_name userName,
  6.             tb1.email,
  7.             tb1.phone,
  8.             tb1.create_time createTime,
  9.             tb1.update_time updateTime,
  10.             tb1.state,
  11.             tb2.school,
  12.             tb2.city_name cityName
  13.         FROM tb_user tb1
  14.         LEFT JOIN tb_user_extd tb2 ON tb1.id = tb2.user_id
  15.         WHERE tb1.state='1'
  16.         ORDER BY tb1.id DESC
  17.     </select>
  18. </mapper>
复制代码
3、单元测试

编写UserMapper接口测试,很多默认实现的方法参考BaseMapper接口即可,或者参考IService接口和ServiceImpl实现类,提供了更加丰富的扩展方法;
  1. public class UserMapperTest {
  2.     @Resource
  3.     private UserMapper userMapper ;
  4.     @Test
  5.     public void testInsert (){
  6.         List<User> userBatch = Arrays.asList(
  7.                 new User(null,"Zhang三","Zhang@qq.com","18623459687",new Date(),new Date(),1));
  8.         userBatch.forEach(userMapper::insert);
  9.     }
  10.     @Test
  11.     public void testUpdate (){
  12.         User user = userMapper.selectById(1);
  13.         user.setState(2);
  14.         userMapper.updateById(user);
  15.     }
  16.    
  17.     @Test
  18.     public void testDelete (){
  19.         userMapper.deleteById(7);
  20.     }
  21.    
  22.     @Test
  23.     public void testQuery (){
  24.         List<User> userColumnsList = new LambdaQueryChainWrapper<>(userMapper)
  25.                 .select(User::getUserName,User::getPhone,User::getEmail)
  26.                 .like(User::getPhone,"189").orderByDesc(User::getId).last("limit 2").list();
  27.         userColumnsList.forEach(System.out::println);
  28.     }
  29.     @Test
  30.     public void testPage (){
  31.         // 1、默认分页查询
  32.         IPage<User> userPage = new Page<>(2,2) ;
  33.         IPage<User> userPageList = userMapper.selectPage(userPage,new QueryWrapper<>());
  34.         userPageList.getRecords().forEach(System.out::println);
  35.         // 2、自定义查询分页
  36.         IPage<UserModel> userModelPage = userMapper.queryUserPage(userPage);
  37.         userModelPage.getRecords().forEach(System.out::println);
  38.     }
  39. }
复制代码
六、参考源码
  1. 文档仓库:
  2. https://gitee.com/cicadasmile/butte-java-note
  3. 源码仓库:
  4. https://gitee.com/cicadasmile/butte-spring-parent
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

忿忿的泥巴坨

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表