Mybatis Plus 使用详解
Mybatis Plus 是Mybatis的增强插件,对数据库操作Mybatis Plus提供了抽象层次比Mybatis更高的操作方法。
Wrapper是Mybatis Plus里拼接sql的包装类。具体的各种查询功能可以查看Mybatis Plus 条件构造器官方文档
一、自定义查询字段
EntityWrapper 的setSqlSelect可以定义需要查询的库表字段。但是很多时候我们查询的数据可能来自不同的表,我们这时候可能需要用到子查询,那么这时候该怎么使用EntityWrapper 呢?
答案是直接写在setSqlSelect里面。例
Wrapper<Res> ew = new EntityWrapper<>();
ew.eq("deleted", 0);
ew.setSqlSelect("*", "(select name from res_type where id=res_type_id) as res_type_name",
"(select name from probe where id=probe_id) as probe_name");
二、条件查询
一个很常见的场景是查询某字段的时候如果值不为空则查询,否则不查询。Mybatis Plus的拼接sql方法有一个条件拼接。
ew.eq(boolean condition,String column,Object params)
public List<Person> findPersonList(String age,String gender){
Wrapper<Res> ew = new EntityWrapper<>();
ew.eq(!"".equals(gender),"gender", 0);
ew.eq(!"".equals(age),"age",age);
}
条件拼接sql的源码如下:
public Wrapper<T> and(boolean condition, String sqlAnd, Object... params) {
if (condition) {
((SqlPlus)this.sql.AND()).WHERE(this.formatSql(sqlAnd, params));
}
return this;
}
我们可以看到是只有条件为true的情况下才拼接sql,否则是不会拼接的。绝大部分Mybatis Plus的操作都支持条件的查询。这样可以节省大量的代码。
三、分页查询
Mybatis Plus分页查询的重点在于Page这个包装类。
- Wrapper查询方式分页
在Controller层我们先构建一个Page包装类,这个包装类的类型应该跟你需要分页的数据类型是一致。例如我们希望返回一个List<Map<String,Object>>格式的数据,我们需要构建一个Page<Map<String,Object>>的page类。
/* 设置页大小,当前页,排序字段,排序方式是否是asc */
Page<Map<String, Object>> page = new Page<>(currentPage, pageSize, "update_time" , false);
Map<String, Object> condition = Maps.newHashMap();
condition.put("age", 23);
/* 如果有查询参数,我们可以放到condition里面去,然后在Service里面获取条件再进行查询*/
page.setCondition(condition);
/* 把分页查询的数据放入records,Mybatis Plus会自动查询出总数据量*/
page.setRecords(this.dataService.findPageData(page));
先new一个page包装类。如果有查询参数,我们可以放到condition里面去,然后在Service里面获取条件再进行查询。注意,把分页查询的数据放入records,Mybatis Plus会自动查询出总数据量,无需再用sql查询总个数之后setTotal。具体的查询我们可以放在Service里面编写。
public List<Map<String, Object>> findPageData(Page<Map<String, Object>> page) {
Wrapper<Res> ew = new EntityWrapper<>();
ew.ge("age", 23);
ew.eq("gender",1)
return baseMapper.selectMapsPage(page, ew);
}
2.自定义sql方式
如果你的sql语句比较特殊,需要自己写sql的话。你的分页可以写到mapper里,或者mapping.xml里面。
public interface PersonMapper{
@Select("select * from person where gender=${gender} oder by age")
List<Person> selectPersonList(Pagination page, @Param("gender") String gender);
}
Service里面直接调用mapper里的方法,如果条件比较复杂,则使用page中的condition来获取字段。
public Page<Person> getTestData(Page<Person> page,String gender){
return page.setRecords(this.baseMapper.selectPersonList(page,gender));
}
Controller里调用Service,相比于上一种方法这个方法简化了Controller层的部分代码。
/* 设置页大小,当前页,排序字段,排序方式是否是asc */
Page<Person> page = new Page<>(currentPage, pageSize);
page.setCondition(condition);
return this.dataService.getTestData(page,"1");
Mybatis Plus 使用详解的更多相关文章
- mybatis代码生成器配置文件详解
mybatis代码生成器配置文件详解 更多详见 http://generator.sturgeon.mopaas.com/index.html http://generator.sturgeon.mo ...
- 深入浅出mybatis之启动详解
深入浅出mybatis之启动详解 MyBatis功能丰富,但使用起来非常简单明了,今天我们来追踪一下它的启动过程. 目录 如何启动MyBatis 如何使用MyBatis MyBatis启动过程 如何启 ...
- MyBatis核心配置文件详解
------------------------siwuxie095 MyBatis 核心配置文件详解 1.核心 ...
- 《深入理解mybatis原理2》 Mybatis初始化机制详解
<深入理解mybatis原理> Mybatis初始化机制详解 对于任何框架而言,在使用前都要进行一系列的初始化,MyBatis也不例外.本章将通过以下几点详细介绍MyBatis的初始化过程 ...
- Mybatis案例超详解(上)
Mybatis案例超详解(上) 前言: 本来是想像之前一样继续跟新Mybatis,但由于种种原因,迟迟没有更新,快开学了,学了一个暑假,博客也更新了不少,我觉得我得缓缓,先整合一些案例练练,等我再成熟 ...
- MyBatis Mapper XML 详解
MyBatis Mapper XML 详解 MyBatis 真正的力量是在映射语句中.这里是奇迹发生的地方.对于所有的力量,SQL 映射的 XML 文件是相当的简单.当然如果你将它们和对等功能的 JD ...
- Mybatis源码详解系列(四)--你不知道的Mybatis用法和细节
简介 这是 Mybatis 系列博客的第四篇,我本来打算详细讲解 mybatis 的配置.映射器.动态 sql 等,但Mybatis官方中文文档对这部分内容的介绍已经足够详细了,有需要的可以直接参考. ...
- mybatis 学习笔记 -详解mybatis 及实例demo
快速入门1 要点: 首先明白mybatis 是什么 这是一个持久层的框架.之前叫做ibatis.所以,在它的代码中出现ibatis这个词的时候,不要感到惊讶.不是写错了,它确实就是这个样子的. 首先, ...
- mybatis核心文件详解
MyBatis配置文件详解 configuration 这是配置文件的根元素标签,所有的其他元素都要在这个标签下使用. environments 用于管理所有环境,并可以指定默认使用哪个环境,通 ...
- MyBatis 全局配置文件详解(七)
MyBatis 配置文件作用 MyBatis配置文件包含影响 MyBatis 框架正常使用的功能设置和属性信息.它的作用好比手机里的设置图标,点击这个图标就可以帮助我们查看手机的属性信息和设置功能.其 ...
随机推荐
- selenium死活定位不到元素以及radio单选框点击不生效
今天操作一个单选框浪费太多时间,现在其实很简单得东西,记录一下: 1,问题一,定位不到 如图,使用selenium IDE和xpath helper都试过,无法成功定位到这个单选框,实际上是因为,这个 ...
- 'pybot.bat' 不是内部或外部命令,也不是可运行的程序
在通过命令行工具 运行RobotFramework的文件, 会使用到pybot.bat. 在dos输入pybot提示'pybot' 不是内部或外部命令,也不是可运行的程序或批处理文件, 可以在pyth ...
- Mysql 查询当前数据上一条和下一条的记录
获取当前文件上一条与下一条记录的原理是上一条的sql语句,从news表里按从大到小的顺序选择一条比当前ID小的新闻,下一条的sql语句,从news表里按从小到大的顺序选择一条比当前ID大的新闻. 如果 ...
- jQuery显示隐藏div的几种方法
1.$("#demo").attr("style","display:none;");//隐藏div $("#demo" ...
- Java对象和集合的拷贝/克隆/复制
昨天同事遇到了一个奇怪的问题,他需要将一个JavaBean拷贝一份,然后对新创建的Bean进行操作.但是他对新的Bean操作后,会影响旧的Bean的值.当听到这个问题的时候,我第一反应就是他的拷贝方法 ...
- Python3 编程第一步_斐波纳契数列_连续赋值
# Fibonacci series: 斐波纳契数列 # 两个元素的总和确定了下一个数 a, b = 0, 1 while b < 10: print(b) a, b = b, a+b # 1 ...
- 安装最新docker-ce失败解决
报错 下载 检查本地是否已经安装 rpm -qa |grep containerd.io 如果有低版本的,卸载即可. 安装新版的containerd.io软件包 wget https://downlo ...
- python3速查参考- python基础 5 -> 常用的文件操作
文件的打开方式 打开方式 详细释义 r 以只读方式打开文件.文件的指针会放在文件的开头.这是默认模式. rb 以二进制只读方式打开一个文件.文件指针会放在文件的开头. r+ 以读写方式打开一个文 ...
- 想了解Java后端学习路线?你只需要这一张图!
前言 学习路线图往往是学习一样技术的入门指南.网上搜到的Java学习路线图也是一抓一大把. 今天我只选一张图,仅此一图,足以包罗Java后端技术的知识点.所谓不求最好,但求最全,学习Java后端的同学 ...
- 【VS开发】CListCtrl控件使用
为何调用了CListCtrl的InsertColumn却什么效果都没有?这个问题以前发现过,今天才清楚,那就是要把它的Style指定为LVS_REPORT. 具体做法如下: 假 ...