2019-04-28 Mybatis generator逆向工程生成的Example代码分析
今天主要对Mybatis generator生成的DAO层等进行分析,讲解Example类的使用和扩展
1.先在数据库建表
CREATE TABLE `department` (
`fid` varchar(255) NOT NULL,
`code` varchar(255) DEFAULT NULL COMMENT '部门代码',
`name` varchar(255) DEFAULT NULL COMMENT '部门名称',
PRIMARY KEY (`fid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
2.创建Mybatis generator配置文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
<context id="context1">
<!-- 去掉注释 -->
<commentGenerator>
<property name="suppressAllComments" value="true" />
</commentGenerator> <!-- 配置连接信息 -->
<jdbcConnection connectionURL="jdbc:mysql://localhost:3306/demo1?serverTimezone=GMT%2B8"
driverClass="com.mysql.cj.jdbc.Driver" password="x5" userId="root" />
<!-- 配置实体类生成路径 -->
<javaModelGenerator targetPackage="com.wf.ew.demo1.model" targetProject="reverse\src\main\java" />
<!-- 配置MapperXML文件生成路径 -->
<sqlMapGenerator targetPackage="com.wf.ew.demo1.dao" targetProject="reverse\src\main\java" />
<!-- 配置DAO层生成路径 -->
<javaClientGenerator targetPackage="com.wf.ew.demo1.dao" targetProject="reverse\src\main\java" type="XMLMAPPER" />
<!-- 配置表和实体类的映射关系 -->
<table tableName="department" domainObjectName="Department">
<!-- <columnOverride column="???" property="???" /> -->
</table> </context> </generatorConfiguration>
3.生成的DepartmentExample
package com.wf.ew.demo1.model; import java.util.ArrayList;
import java.util.List; public class DepartmentExample { /**
* 排序条件
*/
protected String orderByClause; /**
* 去重标识
*/
protected boolean distinct; /**
* 最终以or进行连接的条件列表,Criteria为一个以and连接的条件集
*/
protected List<Criteria> oredCriteria; /**
* 初始化条件描述对象容器列表
*/
public DepartmentExample() {
oredCriteria = new ArrayList<Criteria>();
} // 此处省略orderByClause、distinct的Getter、Setter和oredCriteria的Getter
…… /**
* 增加以and连接的条件集(先补全后增加)
*/
public void or(Criteria criteria) {
oredCriteria.add(criteria);
} /**
* 增加空的以and连接的条件集(先增加后补全)
* @return
*/
public Criteria or() {
Criteria criteria = createCriteriaInternal();
oredCriteria.add(criteria);
return criteria;
} /**
* 增加空的以and连接的条件集(当且仅当容器为空的才能加入)
* @return
*/
public Criteria createCriteria() {
Criteria criteria = createCriteriaInternal();
if (oredCriteria.size() == 0) {
oredCriteria.add(criteria);
}
return criteria;
} /**
* 增加空的条件描述对象容器(内部实现)
* @return
*/
protected Criteria createCriteriaInternal() {
Criteria criteria = new Criteria();
return criteria;
} /**
* 格式化过滤对象
*/
public void clear() {
oredCriteria.clear();
orderByClause = null;
distinct = false;
} /**
* 抽象类:条件描述对象容器(容器内的条件会以and连接)
*/
protected abstract static class GeneratedCriteria {
/**
* 条件描述对象容器
*/
protected List<Criterion> criteria; /**
* 初始化条件描述对象容器
*/
protected GeneratedCriteria() {
super();
criteria = new ArrayList<Criterion>();
} /**
* 判断是否有效(基本条件最少为1)
* @return
*/
public boolean isValid() {
return criteria.size() > 0;
} /**
* 获得所有条件描述对象
* @return
*/
public List<Criterion> getAllCriteria() {
return criteria;
} /**
* 获得条件描述对象容器
* @return
*/
public List<Criterion> getCriteria() {
return criteria;
} /*== 通用增加条件描述对象的方法 == */
/**
* 增加没有没有占位符的条件描述
* @param condition
*/
protected void addCriterion(String condition) {
if (condition == null) {
throw new RuntimeException("Value for condition cannot be null");
}
criteria.add(new Criterion(condition));
} /**
* 增加单占位符的条件描述(没有typeHandler)
* @param condition
* @param value
* @param property
*/
protected void addCriterion(String condition, Object value, String property) {
if (value == null) {
throw new RuntimeException("Value for " + property + " cannot be null");
}
criteria.add(new Criterion(condition, value));
} /**
* 增加区间参数的条件描述(没有typeHandler)
* @param condition
* @param value1
* @param value2
* @param property
*/
protected void addCriterion(String condition, Object value1, Object value2, String property) {
if (value1 == null || value2 == null) {
throw new RuntimeException("Between values for " + property + " cannot be null");
}
criteria.add(new Criterion(condition, value1, value2));
} // 以下省略 fid、code、name的14种条件查询生成(为空、不为空、=、<>、>、>=、<、<=、like、not like、in、not in、between、not between)
…… } /**
* 静态内部类:条件描述对象容器实现类
*
*/
public static class Criteria extends GeneratedCriteria { protected Criteria() {
super();
}
} /**
* 静态内部类:条件描述对象
*
*/
public static class Criterion {
private String condition; // 原子条件 private Object value; // 第一个值 private Object secondValue; // 第二个值 private boolean noValue; // 是否没有值 private boolean singleValue; // 是否单值(与listValue互逆) private boolean betweenValue; // 是否区间值 private boolean listValue; // 是否列表(与singleValue互逆) private String typeHandler; public String getCondition() {
return condition;
} // 此处省略 value、noValue、singleValue、listValue、typeHandler的Getter方法
…… /**
* 创建没有占位符的条件
* @param condition
*/
protected Criterion(String condition) {
super();
this.condition = condition;
this.typeHandler = null;
this.noValue = true;
} /**
* 创建单占位符的条件
* @param condition
* @param value
* @param typeHandler
*/
protected Criterion(String condition, Object value, String typeHandler) {
super();
this.condition = condition;
this.value = value;
this.typeHandler = typeHandler;
if (value instanceof List<?>) {
this.listValue = true;
} else {
this.singleValue = true;
}
} /**
* 创建单占位符的条件(没有typeHandler)
* @param condition
* @param value
*/
protected Criterion(String condition, Object value) {
this(condition, value, null);
} /**
* 创建区间参数的条件
* @param condition
* @param value
* @param secondValue
* @param typeHandler
*/
protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
super();
this.condition = condition;
this.value = value;
this.secondValue = secondValue;
this.typeHandler = typeHandler;
this.betweenValue = true;
} /**
* 创建区间参数的条件(没有typeHandler)
* @param condition
* @param value
* @param secondValue
*/
protected Criterion(String condition, Object value, Object secondValue) {
this(condition, value, secondValue, null);
}
}
}
4.DepartmentExample的分析
- DepartmentExample类中还包含了GeneratedCriteria、Criteria、Criterion三个静态内部类
- Criterion表示一个最小粒度的条件的描述
- GeneratedCriteria是一个抽象类;表示Criterion的集合,元素之间使用and连接
- Criteria是GeneratedCriteria的实现类
- DepartmentExample表示一个SQL语句的where、distinct、order by部分的描述;其中where部分表示Criteria的集合,元素间使用or连接
使用一个例子进行说明
SELECT DISTINCT
*
FROM
maintainbill
WHERE
(
fState = '已完成'
AND
fItemType LIKE '%网络%'
)
OR (
fState = '待安排'
AND
fItemType LIKE '%电脑%'
);
- 7、9、12、14为一个Criterion
- 7、9需要存放到同一个Criteria中
- 12、14需要存放到同一个Criteria中
- 6-15位DepartmentExample的条件部分(以上两个Criteria需要存放入Example的List中)
5.使用DepartmentExample查询的优缺点
优点:
- 因为是代码生成的,可以省去自己写XML和接口方法
- 查询条件灵活
缺点:
- 查删改都需要使用Example,略显繁琐
- 没有分页功能
6.扩展DepartmentExample分页
① 在Example中加入startindex(开始行索引)、limit(记录数)属性及Getter、Setter
②扩展MapperXML中查询列表的select
<if test="startindex !=null and limit !=null">
limit ${startindex},${limit}
</if>
7.补充DepartmentMapper接口的方法说明
package com.wf.ew.demo1.dao; import java.util.List; import org.apache.ibatis.annotations.Param; import com.wf.ew.demo1.model.Department;
import com.wf.ew.demo1.model.DepartmentExample; public interface DepartmentMapper{
/**
* 根据example查询记录数
*/
long countByExample(DepartmentExample example); /**
* 根据example删除记录
*/
int deleteByExample(DepartmentExample example); /**
* 插入行(插入所有属性值)
*/
int insert(Department record); /**
* 插入行(插入非null属性值)
*/
int insertSelective(Department record); /**
* 根据example查询记录
*/
List<Department> selectByExample(DepartmentExample example); /**
* 根据example更新表(更新非null属性)
*/
int updateByExampleSelective(@Param("record") Department record, @Param("example") DepartmentExample example); /**
* 根据example更新表(更新所有属性)
*/
int updateByExample(@Param("record") Department record, @Param("example") DepartmentExample example);
}
2019-04-28 Mybatis generator逆向工程生成的Example代码分析的更多相关文章
- idea 中使用Mybatis Generator逆向工程生成代码
通过MAVEN完成 Mybatis 逆向工程 1. POM文件中添加插件 在 pom 文件的build 标签中 添加 plugin 插件和 数据库连接 jdbc 的依赖. <build> ...
- 在IDEA中使用MyBatis Generator逆向工程生成代码
本文介绍一下用Maven工具如何生成Mybatis的代码及映射的文件. 一.配置Maven pom.xml 文件 在pom.xml增加以下插件: <build> <finalName ...
- Mybatis Generator逆向工程的使用
一.在 idea 中使用 mybatis generator 逆向工程 1.在IDEA上创建maven工程. 2.在pom.xml中配置MyBatis逆向工程插件 <!--MyBatis自动生成 ...
- MyBatis Generator 自定义生成注释
注释生成器 为了生成db里面的注释,必须自定义注释生成器 EmptyCommentGenerator: import org.mybatis.generator.api.CommentGenerato ...
- SpringBoot入门篇--整合mybatis+generator自动生成代码+druid连接池+PageHelper分页插件
原文链接 我们这一篇博客讲的是如何整合Springboot和Mybatis框架,然后使用generator自动生成mapper,pojo等文件.然后再使用阿里巴巴提供的开源连接池druid,这个连接池 ...
- SpringBoot+Mybatis+Generator 逆向工程使用(二)
Mybatis-Genarator 逆向工程使用 个人开发环境 java环境:Jdk1.8.0_60 编译器:IntelliJ IDEA 2017.1.4 mysql驱动:mysql-connecto ...
- 使用Mybatis Generator自动生成Mybatis相关代码
本文将简要介绍怎样利用Mybatis Generator自动生成Mybatis的相关代码: 一.构建一个环境: 1. 首先创建一个表: CREATE TABLE pet (name VARCHAR(2 ...
- SpringBoot 添加mybatis generator 自动生成代码插件
自动生成数据层代码,提高开发效率 1.pom添加插件,并指定配置文件路径 <!-- mybatis generator 自动生成代码插件 --> <plugin> <gr ...
- idea中mybatis generator自动生成代码配置 数据库是sqlserver
好长时间没有写博客了,最近公司要用java语言,开始学习java,属于初学者,今天主要记录一下mybatis generator自动生成代码,首先在如下图的目录中新建两个文件,如下图 generato ...
随机推荐
- 当代前端应该怎么写这个hello world?
前言 大概16年的时候我们队react进行了简单的学习:从DOM操作看Vue&React的前端组件化,顺带补齐React的demo,当时我们只是站在框架角度在学习,随着近几年前端的变化,想写个 ...
- cocos creator主程入门教程(六)—— 消息分发
五邑隐侠,本名关健昌,10年游戏生涯,现隐居五邑.本系列文章以TypeScript为介绍语言. 本篇开始介绍游戏业务架构相关的内容.在游戏业务层,所有需要隔离的系统和模块间通信都可以通过消息分发解耦. ...
- 基于vue-cli快速构建
基于vue-cli快速构建 https://www.jianshu.com/p/2769efeaa10a Vue是近两年来比较火的一个前端框架(渐进式框架吧),与reactjs和angularjs ...
- Java运行时环境---ClassLoader类加载机制
背景:听说ClassLoader类加载机制是进入BAT的必经之路. ClassLoader总述: 普通的Java开发其实用到ClassLoader的地方并不多,但是理解透彻ClassLoader类的加 ...
- 代码托管-gerrit-介绍与环境搭建
什么是gerrit? 转载自 https://blog.csdn.net/tanshizhen119/article/details/79874127 gerrit是谷歌开源的一个git服务端. 主要 ...
- 程序员50题(JS版本)(九)
程序41:八进制转换为十进制 var num1=425; var num2=0; num1=num1.toString(); for(var i=num1.length-1,root=1;i>= ...
- 【20190220】HTTP-知识点整理:TCP/IP与HTTP
TCP/IP是互联网相关的各类协议族的总称,HTTP属于它内部的一个子集. 一.TCP/TP的分层管理 1. 应用层 应用层决定了向用户提供应用服务时通信的活动.TCP/IP 协议族内预存了各类通用的 ...
- 重庆3Shape Dental System技术支持
Dental System 2014中的一些新的功能:为提高生产力增添了自动冠功能软件会自动根据位置设计冠的形状,以适应周围的牙齿和拮抗剂.新的强大的用户体验优化了工作流程和一个新的重新设计的用户界面 ...
- 十款 Chrome 扩展工具,提高前端编码效率
1. 掘金 Chrome 插件 对于开发者来说,比开发过程更重要的,应该要算平时对于开发资源以及技术文章一点一滴的积累了吧.那么,开发者能够在哪里获取需要的技术内容呢?过去,你可能需要在 GitHub ...
- win10下Resin安装--入门(1)
我个人采用是解压版的,直接解压亦可使用下载地址 开启该服务需要的环境:首先你的JDK必须安装成功 解压后你会看到 当我们运行程序时,需要修改配置文件中的相关配置: 1.端口:以免端口被占用 2.相应 ...