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

相关文章

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows