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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

mybatis的整体架构

mybatis的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7