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如何使用Actuator和Micrometer进行健康检查和监控,通过配置和自定义健康指示器,开发者可以实时监控应用组件的状态,... 目录1. 引言重要性2. 配置Spring Boot ActuatorSpring Boot Act

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

C#读取本地网络配置信息全攻略分享

《C#读取本地网络配置信息全攻略分享》在当今数字化时代,网络已深度融入我们生活与工作的方方面面,对于软件开发而言,掌握本地计算机的网络配置信息显得尤为关键,而在C#编程的世界里,我们又该如何巧妙地读取... 目录一、引言二、C# 读取本地网络配置信息的基础准备2.1 引入关键命名空间2.2 理解核心类与方法

java如何分布式锁实现和选型

《java如何分布式锁实现和选型》文章介绍了分布式锁的重要性以及在分布式系统中常见的问题和需求,它详细阐述了如何使用分布式锁来确保数据的一致性和系统的高可用性,文章还提供了基于数据库、Redis和Zo... 目录引言:分布式锁的重要性与分布式系统中的常见问题和需求分布式锁的重要性分布式系统中常见的问题和需求

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.