springboot整合mybatis-plus+durid数据库连接池

特别说明:本次项目整合基于idea进行的,如果使用Eclipse可能操作会略有不同,不过总的来说不影响。

springboot整合之如何选择版本及项目搭建

springboot整合之版本号统一管理  

springboot整合mybatis-plus+durid数据库连接池

springboot整合swagger

springboot整合mybatis代码快速生成​​​​​​​

springboot整合之统一结果返回

springboot整合之统一异常处理

springboot整合之logback日志配置

springboot整合pagehelper分页

springboot整合本地缓存

springboot整合redis + redisson

springboot整合elasticsearch

springboot整合rabbitMq

springboot整合canal实现缓存一致性

springboot整合springSecurity(前后端不分离版本)

本次项目整合基于第一篇的项目搭建,如果需要的可以参考第一篇。里面讲解了怎么进行版本选择,和基础的项目搭建。本篇主要是基于上一篇的基础上进行数据库操作的整合。

其实这里有一个点我觉得有必要说一下,如果不需要开启监控功能,个人觉得没必要用Druid数据库连接池。不如直接使用磨人的Hikari,而且这个连接池不需要进行额外整合,因为springboot已经帮我们整合好了。下面我们来介绍一下这个连接池,希望对你得数据库连接池选择有所帮助。

Hikari是一款非常强大,高效,并且号称“史上最快连接池”。性能方面的比较:hikariCP>druid>tomcat-jdbc>dbcp>c3p0 。hikariCP的高性能得益于最大限度的避免锁竞争。它的性能几乎是C3P0、DBCP的25倍,十分强悍。

一、整合jar包



    4.0.0
    
    
        org.springframework.boot
        spring-boot-starter-parent
        2.3.12.RELEASE
    

    
    com.example
    springboot-demo
    0.0.1-SNAPSHOT
    springboot-demo
    springboot-demo

    
    
        8
    


    

        
        
            org.springframework.boot
            spring-boot-starter
        

        
        
            org.springframework.boot
            spring-boot-starter-web
        

        
        
            org.springframework.boot
            spring-boot-devtools
            runtime
            true
        

        
        
            org.projectlombok
            lombok
            true
        

        
        
            org.springframework.boot
            spring-boot-starter-test
            test
        

        
        
            mysql
            mysql-connector-java
        

        
        
            com.alibaba
            druid-spring-boot-starter
            1.2.15
        

        
        
            com.baomidou
            mybatis-plus-boot-starter
            3.4.2
        

    

    
        
            
                org.springframework.boot
                spring-boot-maven-plugin
                
                    
                        
                            org.projectlombok
                            lombok
                        
                    
                
            
        
    


二、配置applicartion-dev.yml

说明都写在文件里了。大家不懂得可以私信我。

server:
  port: 8080   #  配置启动端口号


spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/test?serverTimezone=GMT%2B8&useSSL=FALSE
    username: root  #数据库用户名,root为管理员
    password: 123456 #该数据库用户的密码
    # 使用druid数据源
    type: com.alibaba.druid.pool.DruidDataSource

# mybatis-plus相关配置
mybatis-plus:
  # xml扫描,多个目录用逗号或者分号分隔(告诉 Mapper 所对应的 XML 文件位置)
  mapper-locations: classpath:mapper/*.xml
  # 以下配置均有默认值,可以不设置
  global-config:
    db-config:
      #主键类型 AUTO:"数据库ID自增" INPUT:"用户输入ID",ID_WORKER:"全局唯一ID (数字类型唯一ID)", UUID:"全局唯一ID UUID";
      id-type: auto
      #字段策略 IGNORED:"忽略判断"  NOT_NULL:"非 NULL 判断")  NOT_EMPTY:"非空判断"
      field-strategy: NOT_EMPTY
      #数据库类型
      db-type: MYSQL
  configuration:
    # 是否开启自动驼峰命名规则映射:从数据库列名到Java属性驼峰命名的类似映射
    map-underscore-to-camel-case: true
    # 如果查询结果中包含空值的列,则 MyBatis 在映射的时候,不会映射这个字段
    call-setters-on-nulls: true
    # 这个配置会将执行的sql打印出来,在开发或测试的时候可以用
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

三、创建项目所需要的包结构

在开始之前我们先准备好项目后面所要用到的包,具体目录如下,大家可以参考着建一下

springboot整合mybatis-plus+durid数据库连接池_第1张图片

 包的分层和结构很简单,相信大家都理解我就不再做特别说明了。

四、修改启动类

在启动类上添加mapper扫描。

package com.example.springbootdemo;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
@MapperScan(basePackages = "com.example.springbootdemo.mapper")
public class SpringbootDemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringbootDemoApplication.class, args);
    }

}

不知道大家清不清楚为什么要使用@MapperScan注解?它和@Mapper有什么区别?

其实这两个作用是相同的。区别就是@Mapper可以单独添加在每个mapper上面,而@MapperScan是只要添加在启动类上就可以了。如果我们在启动类上面添加了@MapperScan注解,那就没有必要再使用@Mapper注解了。如果不使用@MapperScan也可以单独在每一个mapper添加@Mapper注解,效果是一样的,就是比较麻烦而已。

 五、创建数据库

上面都好了我们就可以正式开始创建我们的第一张表来测试我们的整合了。为了简单我这里就直接创建了一个用户表。这样也好理解。好了,不废话了,直接来创建test数据库并创建user表

CREATE TABLE `user` (
  `id` bigint(12) NOT NULL AUTO_INCREMENT,
  `user_name` varchar(8) DEFAULT NULL COMMENT '用户名',
  `password` varchar(50) DEFAULT NULL COMMENT '密码',
  `sex` int(1) DEFAULT '0' COMMENT '性别',
  `phone` varchar(20) DEFAULT NULL COMMENT '手机号',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8

六、创建实体类、mapper、service

表创建完成以后我们就可以按照mybatis-plus来创建我们自己的实体类还有mapper和service了。这里要特别说明一下,使用了Lombok注解,需要安装Lombok的插件,如果没有安装需要自己在idea安装一下。

package com.example.sessiondemo.pojo;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;

import java.io.Serializable;

/**
 * @description: User 
* @date: 2022/7/17 17:27
* @author: William
* @version: 1.0
*/ @Data @TableName("user") public class User implements Serializable { @TableId(type = IdType.AUTO) private Long id; /** * 用户名 */ private String userName; /** * 密码 */ private String password; /** * 性别 */ private Integer sex; /** * 手机号 */ private String phone; }
package com.example.sessiondemo.dao;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.sessiondemo.pojo.User;
import org.apache.ibatis.annotations.Mapper;

/**
 * @description: UserMapper 
* @date: 2022/7/17 17:32
* @author: William
* @version: 1.0
*/ public interface UserMapper extends BaseMapper { }
package com.example.sessiondemo.service;

import com.baomidou.mybatisplus.extension.service.IService;
import com.example.sessiondemo.pojo.User;

/**
 * @description: UserService 
* @date: 2022/7/17 17:33
* @author: William
* @version: 1.0
*/ public interface UserService extends IService { }
package com.example.sessiondemo.service.impl;

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.example.sessiondemo.dao.UserMapper;
import com.example.sessiondemo.pojo.User;
import com.example.sessiondemo.service.UserService;
import org.springframework.stereotype.Service;

/**
 * @description: UserServiceImpl 
* @date: 2022/7/17 17:34
* @author: William
* @version: 1.0
*/ @Service public class UserServiceImpl extends ServiceImpl implements UserService { }

七、测试配置是否成功

创建测试

package com.example.springbootdemo;

import com.example.springbootdemo.entity.User;
import com.example.springbootdemo.mapper.UserMapper;
import com.example.springbootdemo.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
class SpringbootDemoApplicationTests {

    @Autowired
    private UserService userService;
    


    @Test
    void testInsert() {
        User user = new User();
        user.setUserName("aaa").setSex(2).setPhone("1111");
        userService.save(user);
    }

}

输出结果如下:

springboot整合mybatis-plus+durid数据库连接池_第2张图片

 成功执行,说明我们的整合成功了。后面会接着整合开发中常用到的一些插件或者中间件,感兴趣的欢迎关注~

你可能感兴趣的:(springboot,spring,boot,mybatis-plus,druid)