SpringBoot(9)集成Spring Boot2、Mybatis Plus3、mybatis-plus-generator3、Mysql5整合配置测试记录

本文主要是介绍SpringBoot(9)集成Spring Boot2、Mybatis Plus3、mybatis-plus-generator3、Mysql5整合配置测试记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

    • 我的环境
      • 开发软件
      • 框架环境
    • 代码地址
    • 项目结构
    • 整合配置
      • 创建项目
      • 创建数据库、创建一张测试表
      • 创建CodeGenerator类
      • 配置yml
      • 测试整合代码
      • 启动运行测试

我的环境

开发软件

  • IDEA 2019
  • Windows 10
  • MySQL5.5
  • Maven 3.5.4
  • JDK 1.8

框架环境

  • SpringBoot 2.1.8
  • Mybatis Plus 3.2

代码地址

码云链接

项目结构

整合配置项目结构

整合配置

创建项目

使用IDEA 创建一个Spring Boot 项目,以下是我项目使用pom.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.8.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>cn.com.witsystem</groupId><artifactId>mybatis-plus</artifactId><version>0.0.1-SNAPSHOT</version><name>mybatis-plus</name><description>Demo project for Spring Boot</description><properties><java.version>1.8</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-configuration-processor</artifactId><optional>true</optional></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.2.0</version></dependency><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-generator</artifactId><version>3.2.0</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-freemarker</artifactId></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><scope>runtime</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build>
</project>

创建数据库、创建一张测试表

创建数据库,创建表,我创建了一张比较简单的表:

CREATE TABLE `sys_user` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',`name` varchar(30) DEFAULT NULL COMMENT '用户名称',`age` int(11) DEFAULT NULL COMMENT '用户年龄',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

在配置过程中可以插入几条数据,一会测试使用,我插入了一条数据。
测试数据截图

创建CodeGenerator类

代码生成类
这个类是针对 Mybatis Plus Generator 编写的代码自动生成类,本文项目结构图中的controller、service、mapper、xml等都是通过这个类生成的。

package cn.com.witsystem.mybatisplus;import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.core.toolkit.StringPool;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.InjectionConfig;
import com.baomidou.mybatisplus.generator.config.*;
import com.baomidou.mybatisplus.generator.config.po.TableInfo;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;import java.util.ArrayList;
import java.util.List;/*** @description: Mybatis Plus 代码生成* @author: ike* @create: 2019/09/12 23:48*/
public class CodeGenerator {public static void main(String[] args) {// 代码生成器AutoGenerator mpg = new AutoGenerator();// 全局配置GlobalConfig gc = new GlobalConfig();//获得程序当前路径String projectPath = System.getProperty("user.dir");//生成文件的输出目录gc.setOutputDir(projectPath + "/src/main/java");gc.setAuthor("ruyulin");//是否展开输出目录gc.setOpen(false);//实体属性 Swagger2 注解//gc.setSwagger2(true);gc.setBaseResultMap(true);gc.setBaseColumnList(true);gc.setEntityName("%sDO");gc.setControllerName("%sController");gc.setServiceName("%sService");gc.setServiceImplName("%sServiceImpl");gc.setMapperName("%sDao");gc.setXmlName("%sDao");//设置全局配置mpg.setGlobalConfig(gc);// 数据源配置DataSourceConfig dsc = new DataSourceConfig();dsc.setUrl("jdbc:mysql://localhost:3306/mybatis-plus");dsc.setDriverName("com.mysql.cj.jdbc.Driver");dsc.setUsername("root");dsc.setPassword("password");dsc.setDbType(DbType.MYSQL);mpg.setDataSource(dsc);// 包配置PackageConfig pc = new PackageConfig();pc.setModuleName("system");pc.setParent("cn.com.witsystem.mybatisplus");pc.setController("controller");pc.setEntity("domain");pc.setMapper("mapper");pc.setXml("mapper");pc.setService("service");pc.setServiceImpl("service.impl");mpg.setPackageInfo(pc);// 自定义配置  调整 xml 生成目录InjectionConfig cfg = new InjectionConfig() {@Overridepublic void initMap() {}};// 如果模板引擎是 freemarkerString templatePath = "/templates/mapper.xml.ftl";// 自定义输出配置List<FileOutConfig> focList = new ArrayList<>();// 自定义配置会被优先输出focList.add(new FileOutConfig(templatePath) {@Overridepublic String outputFile(TableInfo tableInfo) {// 自定义输出文件名 , 如果你 Entity 设置了前后缀、此处注意 xml 的名称会跟着发生变化!!return projectPath + "/src/main/resources/mapper/" + pc.getModuleName()+ "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;}});cfg.setFileOutConfigList(focList);mpg.setCfg(cfg);// 配置模板TemplateConfig templateConfig = new TemplateConfig();// 关闭 默认 xml文件生成templateConfig.setXml(null);mpg.setTemplate(templateConfig);// 策略配置StrategyConfig strategy = new StrategyConfig();//表名生成策略  下划线转驼峰strategy.setNaming(NamingStrategy.underline_to_camel);//字段名生成策略  下划线转驼峰strategy.setColumnNaming(NamingStrategy.underline_to_camel);//启动lombokstrategy.setEntityLombokModel(true);//实体类添加注解//strategy.entityTableFieldAnnotationEnable(true);//生成 @RestController 控制器strategy.setRestControllerStyle(true);//写于父类中的公共字段//strategy.setSuperEntityColumns("id");//表名,多个英文逗号分割strategy.setInclude("sys_user");//驼峰转连字符strategy.setControllerMappingHyphenStyle(true);//设置表前缀//strategy.setTablePrefix(pc.getModuleName() + "_");mpg.setStrategy(strategy);//设置模板引擎mpg.setTemplateEngine(new FreemarkerTemplateEngine());mpg.execute();}
}

右键运行这个类,稍等就会生成代码

配置yml

spring:### 数据库链接配置datasource:url: jdbc:mysql://localhost:3306/mybatis-plususername: rootpassword: passworddriver-class-name: com.mysql.cj.jdbc.Drivermybatis-plus:type-aliases-package: cn.com.witsystem.mybatisplus.system.domainconfiguration:log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

测试整合代码

修改controller

/*** <p>* 用户表 前端控制器* </p>** @author ruyulin* @since 2019-09-13*/
@RestController
@RequestMapping("/system/users")
public class SysUserController {@AutowiredSysUserService userService;@GetMapping("/{id}")public SysUserDO getUser(@PathVariable("id") int id){SysUserDO user = userService.getById(id);return user;}@GetMapping("/mapper")public SysUserDO getUser(){SysUserDO user = userService.getUser(1);return user;}
}

修改service层代码

package cn.com.witsystem.mybatisplus.system.service;import cn.com.witsystem.mybatisplus.system.domain.SysUserDO;
import com.baomidou.mybatisplus.extension.service.IService;/*** <p>* 用户表 服务类* </p>** @author ruyulin* @since 2019-09-13*/
public interface SysUserService extends IService<SysUserDO> {/*** @Description: 通过用户id获取用户信息* @Author: ike* @Date: 2019/9/13 20:46* @Param i: 用户主键* @return: cn.com.witsystem.mybatisplus.system.domain.SysUserDO*/SysUserDO getUser(int id);
}
package cn.com.witsystem.mybatisplus.system.service.impl;import cn.com.witsystem.mybatisplus.system.domain.SysUserDO;
import cn.com.witsystem.mybatisplus.system.mapper.SysUserDao;
import cn.com.witsystem.mybatisplus.system.service.SysUserService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.stereotype.Service;/*** <p>* 用户表 服务实现类* </p>** @author ruyulin* @since 2019-09-13*/
@Service
public class SysUserServiceImpl extends ServiceImpl<SysUserDao, SysUserDO> implements SysUserService {@Overridepublic SysUserDO getUser(int id) {return baseMapper.getUser(id);}
}

修改mapper层代码

package cn.com.witsystem.mybatisplus.system.mapper;import cn.com.witsystem.mybatisplus.system.domain.SysUserDO;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;/*** <p>* 用户表 Mapper 接口* </p>** @author ruyulin* @since 2019-09-13*/
@Mapper
public interface SysUserDao extends BaseMapper<SysUserDO> {SysUserDO getUser(int id);
}

修改映射xml代码

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.com.witsystem.mybatisplus.system.mapper.SysUserDao"><!-- 通用查询映射结果 --><resultMap id="BaseResultMap" type="cn.com.witsystem.mybatisplus.system.domain.SysUserDO"><id column="id" property="id" /><result column="name" property="name" /><result column="age" property="age" /></resultMap><!-- 通用查询结果列 --><sql id="Base_Column_List">id, name, age</sql><select id="getUser" parameterType="int" resultType="cn.com.witsystem.mybatisplus.system.domain.SysUserDO">select * from sys_user where id = #{id}</select></mapper>

启动运行测试

在这里插入图片描述

这篇关于SpringBoot(9)集成Spring Boot2、Mybatis Plus3、mybatis-plus-generator3、Mysql5整合配置测试记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/252578

相关文章

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

Java中如何正确的停掉线程

《Java中如何正确的停掉线程》Java通过interrupt()通知线程停止而非强制,确保线程自主处理中断,避免数据损坏,线程池的shutdown()等待任务完成,shutdownNow()强制中断... 目录为什么不强制停止为什么 Java 不提供强制停止线程的能力呢?如何用interrupt停止线程s

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置