• SpringBoot 整合mybatis,mybatis-plus


    前言

    在真实的项目开发中,使用SpringBoot可以说非常普遍了,而在框架整合中,与数据库的交互无外乎使用jpa,mybatis,mybatis-plus这几种,虽然hibernate仍然有在使用,毕竟框架毕竟重,而且用起来相较于mybatis还是差了那么点意思;

    接下来演示下使用 SpringBoot 同时与mybatis,mybatis-plus的整合步骤;

    准备工作

    1、准备如下一个数据表

    1. CREATE TABLE `student` (
    2. `id` varchar(32) NOT NULL,
    3. `gender` varchar(32) DEFAULT NULL,
    4. `age` int(12) DEFAULT NULL,
    5. `nick_name` varchar(32) DEFAULT NULL,
    6. `name` varchar(32) DEFAULT NULL,
    7. PRIMARY KEY (`id`)
    8. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

    2、插入几条测试数据

     

    整合步骤

    工程的完整包结构如图所示

     

    1、导入maven依赖

    1. <parent>
    2. <groupId>org.springframework.boot</groupId>
    3. <artifactId>spring-boot-starter-parent</artifactId>
    4. <version>2.1.1.RELEASE</version>
    5. <relativePath/> <!-- lookup parent from repository -->
    6. </parent>
    7. <properties>
    8. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    9. <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    10. <java.version>1.8</java.version>
    11. <mysql-connector-java.version>8.0.11</mysql-connector-java.version>
    12. <commons-lang3.version>3.7</commons-lang3.version>
    13. <fastjson.version>1.2.47</fastjson.version>
    14. <mybatis-plus-boot-starter.version>3.3.0</mybatis-plus-boot-starter.version>
    15. <mybatis-plus-generator.version>3.3.0</mybatis-plus-generator.version>
    16. <druid.version>1.1.14</druid.version>
    17. <lombok.version>1.18.0</lombok.version>
    18. <dubbo-spring-boot-starter.version>2.0.0</dubbo-spring-boot-starter.version>
    19. <swagger.version>2.9.2</swagger.version>
    20. <swagger-bootstrap-ui.version>1.9.6</swagger-bootstrap-ui.version>
    21. </properties>
    22. <dependencies>
    23. <dependency>
    24. <groupId>org.apache.commons</groupId>
    25. <artifactId>commons-lang3</artifactId>
    26. <version>3.4</version>
    27. </dependency>
    28. <dependency>
    29. <groupId>org.springframework.boot</groupId>
    30. <artifactId>spring-boot-starter-web</artifactId>
    31. </dependency>
    32. <!--mysql依赖-->
    33. <dependency>
    34. <groupId>mysql</groupId>
    35. <artifactId>mysql-connector-java</artifactId>
    36. <version>${mysql-connector-java.version}</version>
    37. </dependency>
    38. <!--阿里巴巴fastjosn依赖-->
    39. <dependency>
    40. <groupId>com.alibaba</groupId>
    41. <artifactId>fastjson</artifactId>
    42. <version>${fastjson.version}</version>
    43. </dependency>
    44. <!--阿里巴巴数据库连接池依赖-->
    45. <!-- Druid -->
    46. <dependency>
    47. <groupId>com.alibaba</groupId>
    48. <artifactId>druid-spring-boot-starter</artifactId>
    49. <version>${druid.version}</version>
    50. </dependency>
    51. <dependency>
    52. <groupId>org.mybatis.spring.boot</groupId>
    53. <artifactId>mybatis-spring-boot-starter</artifactId>
    54. <version>2.1.1</version>
    55. </dependency>
    56. <!-- MyBatis增强工具-->
    57. <dependency>
    58. <groupId>com.baomidou</groupId>
    59. <artifactId>mybatis-plus-boot-starter</artifactId>
    60. <version>${mybatis-plus-boot-starter.version}</version>
    61. </dependency>
    62. <dependency>
    63. <groupId>com.baomidou</groupId>
    64. <artifactId>mybatis-plus-generator</artifactId>
    65. <version>${mybatis-plus-generator.version}</version>
    66. </dependency>
    67. <!-- lombok -->
    68. <dependency>
    69. <groupId>org.projectlombok</groupId>
    70. <artifactId>lombok</artifactId>
    71. <version>${lombok.version}</version>
    72. </dependency>
    73. <!--swagger-ui-->
    74. <dependency>
    75. <groupId>io.springfox</groupId>
    76. <artifactId>springfox-swagger2</artifactId>
    77. <version>${swagger.version}</version>
    78. </dependency>
    79. <dependency>
    80. <groupId>io.springfox</groupId>
    81. <artifactId>springfox-swagger-ui</artifactId>
    82. <version>${swagger.version}</version>
    83. </dependency>
    84. <dependency>
    85. <groupId>com.github.xiaoymin</groupId>
    86. <artifactId>swagger-bootstrap-ui</artifactId>
    87. <version>${swagger-bootstrap-ui.version}</version>
    88. </dependency>
    89. </dependencies>

    2、配置文件 application.yml

    1. server:
    2. port: 8083
    3. logging:
    4. config: classpath:logback-spring.xml #日志
    5. spring:
    6. datasource:
    7. driver-class-name: com.mysql.cj.jdbc.Driver
    8. url: jdbc:mysql://IP:3306/school?autoReconnect=true&useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8&useSSL=false
    9. username: root
    10. password: root
    11. druid:
    12. max-active: 100
    13. initial-size: 10
    14. max-wait: 60000
    15. min-idle: 5
    16. #设置单个文件最大上传大小
    17. servlet:
    18. multipart:
    19. max-file-size: 20MB
    20. mybatis-plus:
    21. mapper-locations: classpath*:mapper/*.xml
    22. global-config:
    23. db-column-underline: true #开启驼峰转换
    24. db-config:
    25. id-type: uuid
    26. field-strategy: not_null
    27. refresh: true
    28. configuration:
    29. map-underscore-to-camel-case: true
    30. #log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #打印sql语句便于调试

    3、为了方便后面调试接口,增加一个swagger的配置

    1. import org.springframework.context.annotation.Bean;
    2. import org.springframework.context.annotation.Configuration;
    3. import springfox.documentation.builders.ApiInfoBuilder;
    4. import springfox.documentation.builders.PathSelectors;
    5. import springfox.documentation.builders.RequestHandlerSelectors;
    6. import springfox.documentation.service.ApiInfo;
    7. import springfox.documentation.spi.DocumentationType;
    8. import springfox.documentation.spring.web.plugins.Docket;
    9. import springfox.documentation.swagger2.annotations.EnableSwagger2;
    10. /**
    11. * swagger文档,项目启动后,浏览器访问:http://localhost:8083/swagger-ui.html
    12. */
    13. @Configuration
    14. @EnableSwagger2
    15. public class ApiSwagger2 {
    16. @Bean
    17. public Docket createRestBmbsApi() {
    18. return new Docket(DocumentationType.SWAGGER_2)
    19. .groupName("users")
    20. .apiInfo(apiInfo())
    21. .select()
    22. .apis(RequestHandlerSelectors.basePackage("com.congge.controller"))
    23. .paths(PathSelectors.any())
    24. .build();
    25. }
    26. private ApiInfo apiInfo() {
    27. return new ApiInfoBuilder()
    28. .title("后端相关API")
    29. .version("1.0")
    30. .build();
    31. }
    32. }

    4、实体类

    1. import com.baomidou.mybatisplus.annotation.TableField;
    2. import lombok.Data;
    3. @Data
    4. public class Student {
    5. @TableField("id")
    6. private String id;
    7. @TableField("name")
    8. private String name;
    9. @TableField("gender")
    10. private String gender;
    11. @TableField("age")
    12. private int age;
    13. @TableField("nick_name")
    14. private String nickName;
    15. }

    5、dao接口,里面添加一个查询所有数据的方法

    1. import com.baomidou.mybatisplus.core.mapper.BaseMapper;
    2. import com.congge.entity.Student;
    3. import org.apache.ibatis.annotations.Mapper;
    4. import java.util.List;
    5. @Mapper
    6. public interface StudentMapper extends BaseMapper<Student> {
    7. List<Student> queryAll();
    8. }

    6、mybatis层,写sql的文件

    1. <?xml version="1.0" encoding="UTF-8"?>
    2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    3. <mapper namespace="com.congge.dao.StudentMapper">
    4. <select id="queryAll" resultType="com.congge.entity.Student">
    5. select * from student
    6. </select>
    7. </mapper>

    7、业务实现类

    在本次的业务实现中,同时可以使用mybatis的方式以及mybatis-plus的方式进行,具体使用的时候结合自身的需求进行选择;

    1. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
    2. import com.congge.dao.StudentMapper;
    3. import com.congge.entity.Student;
    4. import com.congge.service.StudentService;
    5. import org.springframework.stereotype.Service;
    6. import javax.annotation.Resource;
    7. import java.util.List;
    8. @Service
    9. public class StudentServiceImpl implements StudentService {
    10. @Resource
    11. private StudentMapper studentMapper;
    12. @Override
    13. public List<Student> queryAllStudent() {
    14. QueryWrapper<Student> queryWrapper = new QueryWrapper();
    15. List<Student> students = studentMapper.selectList(queryWrapper);
    16. return students;
    17. //return studentMapper.queryAll();
    18. }
    19. @Override
    20. public List<Student> getByName(String name) {
    21. QueryWrapper<Student> queryWrapper = new QueryWrapper();
    22. queryWrapper.like("name",name);
    23. return studentMapper.selectList(queryWrapper);
    24. }
    25. public Student getById(String id) {
    26. QueryWrapper<Student> queryWrapper = new QueryWrapper();
    27. queryWrapper.like("id",id);
    28. return studentMapper.selectOne(queryWrapper);
    29. }
    30. }

    8、添加一个测试接口

    1. @RestController
    2. public class StudentController {
    3. @Autowired
    4. private StudentService studentService;
    5. @GetMapping("/getAll")
    6. public List<Student> getAll(){
    7. return studentService.queryAllStudent();
    8. }
    9. @GetMapping("/getByName")
    10. public List<Student> getByName(@RequestParam String name){
    11. return studentService.getByName(name);
    12. }
    13. @GetMapping("/getById")
    14. public Student getById(@RequestParam String id){
    15. return studentService.getById(id);
    16. }
    17. }

    9、启动类

    1. import org.springframework.boot.SpringApplication;
    2. import org.springframework.boot.autoconfigure.SpringBootApplication;
    3. @SpringBootApplication
    4. public class App {
    5. public static void main(String[] args) {
    6. SpringApplication.run(App.class,args);
    7. }
    8. }

    接下来,将工程运行起来做一下测试吧

    10、启动之后,打开swagger界面

     

     

    不妨随机测试两个接口吧,测试下获取所有学生的数据接口

     

    本篇到这里基本上就结束了,更多的业务大家可以结合自身的实际情况,继续在代码中补充即可

  • 相关阅读:
    qt简易网络聊天室 数据库的练习
    CV计算机视觉每日开源代码Paper with code速览-2023.10.20
    基于PSO的UAV三维路径规划(Matlab代码实现)
    多标签与多分类的区别
    Maven——采用profile设定不同的开发环境切换
    FPGA project : flash_secter_erase
    ​​​​​​​等级保护差距测评工作实施方案
    英语什么时候加s和es
    YbtOJ「动态规划」第1章 背包问题
    2防火墙:基础知识
  • 原文地址:https://blog.csdn.net/congge_study/article/details/125433452