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

相关文章

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

SpringBoot3.X 整合 MinIO 存储原生方案

《SpringBoot3.X整合MinIO存储原生方案》本文详细介绍了SpringBoot3.X整合MinIO的原生方案,从环境搭建到核心功能实现,涵盖了文件上传、下载、删除等常用操作,并补充了... 目录SpringBoot3.X整合MinIO存储原生方案:从环境搭建到实战开发一、前言:为什么选择MinI

MyBatis中$与#的区别解析

《MyBatis中$与#的区别解析》文章浏览阅读314次,点赞4次,收藏6次。MyBatis使用#{}作为参数占位符时,会创建预处理语句(PreparedStatement),并将参数值作为预处理语句... 目录一、介绍二、sql注入风险实例一、介绍#(井号):MyBATis使用#{}作为参数占位符时,会

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu