使用Mybatis Generator插件生成纯净代码,自定义扩展注释和注释,xml映射文件,不用修改源码!!!

本文主要是介绍使用Mybatis Generator插件生成纯净代码,自定义扩展注释和注释,xml映射文件,不用修改源码!!!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先看效果: (基于Mybatis-generator-core-1.4.0)

生成模型(实体): 根据MySQL库中的tb_prod_info表字段及注释自动生成.

package com.ezsyn.cloudstudy.product.dao.entity;import io.swagger.annotations.ApiModelProperty;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;/*** 产品信息表* <p>* tb_prod_info** @author Aylven* @date 2020-04-06*/
@Getter
@Setter
@ToString
public class TbProdInfo implements Serializable {private static final long serialVersionUID = 1L;/*** 产品代码 主键*/@ApiModelProperty(value = "产品代码 主键")private String code;/*** 产品名称*/@ApiModelProperty(value = "产品名称")private String name;/*** 是否有效*/@ApiModelProperty(value = "是否有效")private Boolean enabled;/*** 创建时间*/@ApiModelProperty(value = "创建时间")private Date createTime;/*** 创建人ID*/@ApiModelProperty(value = "创建人ID")private Integer createBy;/*** 更新时间*/@ApiModelProperty(value = "更新时间")private Date updateTime;/*** 更新人ID*/@ApiModelProperty(value = "更新人ID")private Integer updateBy;
}

生成Mapper接口:生成常用的接口方法,自动生成注释,添加了@Mapper注解.

package com.ezsyn.cloudstudy.product.dao.mapper;import com.ezsyn.cloudstudy.product.dao.entity.TbProdInfo;
import org.apache.ibatis.annotations.Mapper;/*** 产品信息表* <p>* tb_prod_info** @author Aylven* @date 2020-04-06*/
@Mapper
public interface TbProdInfoMapper {/*** 根据主键删除记录*/int deleteByPrimaryKey(String code);/*** 插入全部字段*/int insert(TbProdInfo record);/*** 插入选择的字段*/int insertSelective(TbProdInfo record);/*** 根据主键查询*/TbProdInfo selectByPrimaryKey(String code);/*** 根据主键更新选择的字段*/int updateByPrimaryKeySelective(TbProdInfo record);/*** 根据主键更新全部字段*/int updateByPrimaryKey(TbProdInfo record);
}

生成mapper XML映射文件:去掉了接口方法中的jdbcType

<?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="com.ezsyn.cloudstudy.product.dao.mapper.TbProdInfoMapper"><resultMap id="BaseResultMap" type="com.ezsyn.cloudstudy.product.dao.entity.TbProdInfo"><id column="code" jdbcType="VARCHAR" property="code"/><result column="name" jdbcType="VARCHAR" property="name"/><result column="price" jdbcType="DECIMAL" property="price"/><result column="stock" jdbcType="INTEGER" property="stock"/><result column="enabled" jdbcType="BIT" property="enabled"/><result column="create_time" jdbcType="TIMESTAMP" property="createTime"/><result column="create_by" jdbcType="INTEGER" property="createBy"/><result column="update_time" jdbcType="TIMESTAMP" property="updateTime"/><result column="update_by" jdbcType="INTEGER" property="updateBy"/></resultMap><sql id="Base_Column_List">code, name, price, stock, enabled, create_time, create_by, update_time, update_by</sql><select id="selectByPrimaryKey" parameterType="java.lang.String" resultMap="BaseResultMap">select<include refid="Base_Column_List"/>from tb_prod_infowhere code = #{code}</select><delete id="deleteByPrimaryKey" parameterType="java.lang.String">deletefrom tb_prod_infowhere code = #{code}</delete><insert id="insert" parameterType="com.ezsyn.cloudstudy.product.dao.entity.TbProdInfo"><selectKey keyProperty="code" order="AFTER" resultType="java.lang.String">SELECT LAST_INSERT_ID()</selectKey>insert into tb_prod_info (code, name, price,stock, enabled, create_time,create_by, update_time, update_by)values (#{code}, #{name}, #{price},#{stock}, #{enabled}, #{createTime},#{createBy}, #{updateTime}, #{updateBy})</insert><insert id="insertSelective" parameterType="com.ezsyn.cloudstudy.product.dao.entity.TbProdInfo"><selectKey keyProperty="code" order="AFTER" resultType="java.lang.String">SELECT LAST_INSERT_ID()</selectKey>insert into tb_prod_info<trim prefix="(" suffix=")" suffixOverrides=",">code,<if test="name != null">name,</if><if test="price != null">price,</if><if test="stock != null">stock,</if><if test="enabled != null">enabled,</if><if test="createTime != null">create_time,</if><if test="createBy != null">create_by,</if><if test="updateTime != null">update_time,</if><if test="updateBy != null">

这篇关于使用Mybatis Generator插件生成纯净代码,自定义扩展注释和注释,xml映射文件,不用修改源码!!!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

MyBatis延迟加载与多级缓存全解析

《MyBatis延迟加载与多级缓存全解析》文章介绍MyBatis的延迟加载与多级缓存机制,延迟加载按需加载关联数据提升性能,一级缓存会话级默认开启,二级缓存工厂级支持跨会话共享,增删改操作会清空对应缓... 目录MyBATis延迟加载策略一对多示例一对多示例MyBatis框架的缓存一级缓存二级缓存MyBat

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

Redis中Set结构使用过程与原理说明

《Redis中Set结构使用过程与原理说明》本文解析了RedisSet数据结构,涵盖其基本操作(如添加、查找)、集合运算(交并差)、底层实现(intset与hashtable自动切换机制)、典型应用场... 目录开篇:从购物车到Redis Set一、Redis Set的基本操作1.1 编程常用命令1.2 集

Redis中的有序集合zset从使用到原理分析

《Redis中的有序集合zset从使用到原理分析》Redis有序集合(zset)是字符串与分值的有序映射,通过跳跃表和哈希表结合实现高效有序性管理,适用于排行榜、延迟队列等场景,其时间复杂度低,内存占... 目录开篇:排行榜背后的秘密一、zset的基本使用1.1 常用命令1.2 Java客户端示例二、zse

mysql8.0.43使用InnoDB Cluster配置主从复制

《mysql8.0.43使用InnoDBCluster配置主从复制》本文主要介绍了mysql8.0.43使用InnoDBCluster配置主从复制,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录1、配置Hosts解析(所有服务器都要执行)2、安装mysql shell(所有服务器都要执行)3、