参考:github,   https://github.com/liuxiaochen0625/MyBatis-Spring-Boot-master.git

从controller组装tk.mybatis.mapper.entity.Example 对象,操作起来较为麻烦,不符合我们日常书写习惯,因而改造一下。

调用方法:

WhereBuilder builder = new WhereBuilder(UserInfo.class);
Example example = builder.and("username", OP.EQ, username).or("username", OP.EQ, "tom").and("password", OP.EQ, password).build();

链式操作,是不是很方便?~

具体WhereBuilder构造是参考android xutils的WhereBuilder和StringBuffer写的,如下:

public class WhereBuilder {
private final Example example; //定义examle对象,用于返回 public WhereBuilder(Class<?> tClass){this.example = new Example(tClass);}//构造方法中传入Class参数,实例化example public WhereBuilder and(String columnName,String op,Object value){ //and
Example.Criteria criteria = example.createCriteria();
assembleParams(criteria,columnName,op,value);
return this;
} public WhereBuilder or(String columnName,String op,Object value){ //or
Example.Criteria criteria = example.createCriteria();
assembleParams(criteria,columnName,op,value);
example.or(criteria); //or 需要example调用or(Example.Criteria criteria) 方法
return this;
} private void assembleParams(Example.Criteria criteria,String columnName,String op,Object value){ //组装参数
switch (op) {
case OP.LIKE:
if (!CommonUtils.isEmpty(value)) {
criteria.andLike(columnName, "%" + value + "%");
}
break;
case OP.LEFT_LIKE:
if (!CommonUtils.isEmpty(value)) {
criteria.andLike(columnName, "%" + value);
}
break;
case OP.LIKE_RIGHT:
if (!CommonUtils.isEmpty(value)) {
criteria.andLike(columnName, value + "%");
}
break;
case OP.EQ:
if (!CommonUtils.isEmpty(value)) {
criteria.andEqualTo(columnName, value);
}
break;
case OP.NE:
if (!CommonUtils.isEmpty(value)) {
criteria.andNotEqualTo(columnName, value);
}
break;
case OP.GT:
if (!CommonUtils.isEmpty(value)) {
criteria.andGreaterThan(columnName, value);
}
break;
case OP.NL:
if (!CommonUtils.isEmpty(value)) {
criteria.andGreaterThanOrEqualTo(columnName, value);
}
break;
case OP.LT:
if (!CommonUtils.isEmpty(value)) {
criteria.andLessThan(columnName, value);
}
break;
case OP.NG:
if (!CommonUtils.isEmpty(value)) {
criteria.andLessThanOrEqualTo(columnName, value);
}
break;
case OP.NULL:
criteria.andIsNull(columnName);
break;
case OP.NOTNULL:
criteria.andIsNotNull(columnName);
break;
case OP.IN:
if (!CommonUtils.isEmpty(value)) {
if (value instanceof ArrayList)
criteria.andIn(columnName, (ArrayList) value);
}
break;
case OP.BETWEEN:
if (!CommonUtils.isEmpty(value)) {
if (value instanceof ArrayList) {
criteria.andBetween(columnName, ((ArrayList) value).get(0),
((ArrayList) value).get(1));
}
}
break;
case OP.NOTBETWEEN:
if (!CommonUtils.isEmpty(value)) {
if (value instanceof ArrayList) {
criteria.andNotBetween(columnName, ((ArrayList) value).get(0),
((ArrayList) value).get(1));
}
}
break;
case OP.NOTIN:
if (!CommonUtils.isEmpty(value)) {
if (value instanceof ArrayList)
criteria.andNotIn(columnName, (ArrayList) value);
}
break;
default:
} } public Example build(){ //返回example实例
return example;
} }

建造者模式组装mybatis参数Example()的更多相关文章

  1. 8、Builder 建造者模式 组装复杂的实例 创造型模式

    1.什么是Builder模式 定义: 将一个复杂对象的构建与表示相分离,使得同样的构建过程可以创建不同的表示.大白话就是,你不需要知道这个类的内部是什么样的,只用把想使用的参数传进去就可以了,达到了解 ...

  2. JAVA设计模式 4【创建型】理解建造者模式

    Hello,又是拖了几天更,实在是忙的要死,有时候忙累了,真的就是倒头睡的那种,刚好今天闲下来了.今天来更新一篇建造者模式. 其实建造者模式,我们已经在上一节已经有了解过了.只不过是上一节没有提到这样 ...

  3. 我的强迫症系列之@Builder和建造者模式

    前言 备受争议的Lombok,有的人喜欢它让代码更整洁,有的人不喜欢它,巴拉巴拉一堆原因.在我看来Lombok唯一的缺点可能就是需要安装插件了,但是对于业务开发的项目来说,它的优点远远超过缺点. 我们 ...

  4. 设计模式实战系列之@Builder和建造者模式

    前言 备受争议的Lombok,有的人喜欢它让代码更整洁,有的人不喜欢它,巴拉巴拉一堆原因.在我看来Lombok唯一的缺点可能就是需要安装插件了,但是对于业务开发的项目来说,它的优点远远超过缺点. 我们 ...

  5. 设计模式系列之建造者模式(Builder Pattern)——复杂对象的组装与创建

    说明:设计模式系列文章是读刘伟所著<设计模式的艺术之道(软件开发人员内功修炼之道)>一书的阅读笔记.个人感觉这本书讲的不错,有兴趣推荐读一读.详细内容也可以看看此书作者的博客https:/ ...

  6. 【原】iOS设计模式之:建造者模式Builder Pattern,用于改进初始化参数

    本文主要讨论一下iOS中的Builder Pattern.与网上很多版本不同,本文不去长篇大论地解释建造者模式的概念,那些东西太虚了.设计模式这种东西是为了解决实际问题的,不能为了设计模式而设计模式, ...

  7. iOS设计模式之:建造者模式Builder Pattern,用于改进初始化参数

    转自:http://www.cnblogs.com/wengzilin/p/4365855.html 本文主要讨论一下iOS中的Builder Pattern.与网上很多版本不同,本文不去长篇大论地解 ...

  8. 建造者模式(Builder)——从组装电脑开始

    建造者模式(Builder)--从组装电脑开始 建造者模式概括起来就是将不同独立的组件按照一定的条件组合起来构成一个相对业务完整的对象.调用者无需知道构造的过程. 我们从组装电脑开始 让我们从买组装电 ...

  9. 《Mybatis 手撸专栏》第10章:使用策略模式,调用参数处理器

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 你这代码写的,咋这么轴呢! 说到轴,让我想起初中上学时老师说的话:"你那脑 ...

随机推荐

  1. iOS之解决崩溃Collection <__NSArrayM: 0xb550c30> was mutated while being enumerated.

    崩溃提示:Terminating app due to uncaught exception 'NSGenericException', reason: '*** Collection <CAL ...

  2. MySQL全文索引 FULLTEXT索引和like的区别

    1.概要 InnoDB引擎对FULLTEXT索引的支持是MySQL5.6新引入的特性,之前只有MyISAM引擎支持FULLTEXT索引.对于FULLTEXT索引的内容可以使用MATCH()-AGAIN ...

  3. 在Linux虚拟机下配置jdk的环境变量

    1.到Oracle公司的官网里下载好jdk,网址 http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133 ...

  4. AutoMapper(四)

    返回总目录 自定义值解析 虽然AutoMapper覆盖了相当一部分目标成员的映射场景,但是还有 1-5%的目标值需要解析处理一下.很多时候,自定义的值解析是可以放在领域层的领域逻辑.然而,如果该逻辑只 ...

  5. Async和Await异步编程的原理

    1. 简介 从4.0版本开始.NET引入并行编程库,用户能够通过这个库快捷的开发并行计算和并行任务处理的程序.在4.5版本中.NET又引入了Async和Await两个新的关键字,在语言层面对并行编程给 ...

  6. 从Java文件到字节码文件

    本文涉及的javac编译器来自openjdk. javac的目录地址为:解压目录/langtools/src/share/classes/com/sun/tools/javac/ javac编译器将J ...

  7. appserv 安装php的memcache扩展。

    http://www.cnblogs.com/yiluxiuxing/p/4267709.html 1. 新建一个phpinfo,查看版本号 2. http://museum.php.net/php5 ...

  8. 【原】关于Python中setuptools安装的问题

    在生成package的时候,需要在setup.py中引入setuptools包,可是却报告如下错误: ImportError: No module named setuptools 解决办法就是下载s ...

  9. eclipse内下载及配置maven插件(转)

    本文介绍Maven的安装和配置,同样适用于eclipse 1.首先需要安装jdk,eclipse(废话!). 然后到maven官网下载maven,http://maven.apache.org/dow ...

  10. [原创]MYSQL中利用外键实现级联删除和更新

    MySQL中利用外键实现级联删除.更新 MySQL支持外键的存储引擎只有InnoDB,在创建外键的时候,要求父表必须有对应的索引,子表在创建外键的时候也会自动创建对应的索引.在创建索引的时候,可以指定 ...