最近在用 Mybatis-Plus,嗯,真香!!!今天就来说说 Mybatis-Plus 的那些使用技巧

1、条件查询(QueryWrapper)

如果说,我们需要查询的 SQL 语句如下:

SELECT * FROM user_info WHERE age = 20

那么对应的代码可以为:

QueryWrapper<UserInfo> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("age", 20);
List<UserInfo> list = userInfoMapper.selectList(queryWrapper );

以上就是查询用户表,用户年龄等于20的用户信息

2、条件查询(QueryWrapper lambda)

QueryWrapper<UserInfo> queryWrapper = new QueryWrapper<>();
queryWrapper.lambda().eq(UserInfo::getAge, 20);
List<UserInfo> list = userInfoMapper.selectList(queryWrapper );

以上就是 QueryWrapper 的 lambda 表达式写法,这样能够避免写字段名写错,或者未转换驼峰写法导致 SQL 错误

3、条件查询(LambdaQueryWrapper)

LambdaQueryWrapper<UserInfo> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserInfo::getAge, 20);
List<UserInfo> list = userInfoMapper.selectList(queryWrapper );

LambdaQueryWrapper 与 QueryWrapper 的 lambda 写法基本一致

4、分页查询

// 条件查询
LambdaQueryWrapper<UserInfo> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserInfo::getAge, 20);
// 分页对象
Page<UserInfo> queryPage = new Page<>(page, limit);
// 分页查询
IPage<UserInfo> iPage = userInfoMapper.selectPage(queryPage , queryWrapper);
// 数据总数
Long total = iPage.getTotal();
// 集合数据
List<UserInfo> list = iPage.getRecords();

以上就是分页查询,如果无需条件查询,queryWrapper 可为 null

5、分页查询(联表)

当我们需要关联表格分页查询时,第3步已经满足不了我们的需求了,那么我们需要进行联表分页查询

假设我们需要的 SQL 语句如下:

SELECTa.*,b.`name` AS sex_text
FROMuser_info aLEFT JOIN user_sex b ON ( a.sex = b.id )
WHERE1 = 1 AND a.age > 20

那么我们需要进行如下操作:

  • 1、新建 UserInfoVO.java
import com.zyxx.entity.UserInfo;
import lombok.Data;@Data
public class UserInfoVO extends UserInfo {// 性别private String sexText;
}
123456789

  • 2、UserInfoMapper.java 中
IPage<UserInfoVO> list(Page<UserInfoVO> page, @Param(Constants.WRAPPER) Wrapper<UserInfoVO> queryWrapper);

  • 3、UserInfoMapper.xml 中
<select id="list" resultType="com.zyxx.vo.UserInfoVO">SELECTa.*,b.`name` AS sex_text FROMuser_info aLEFT JOIN user_sex b ON ( a.sex = b.id ) ${ew.customSqlSegment}
</select>

  • 4、UserInfoServiceImpl.java 中
// 条件查询
LambdaQueryWrapper<UserInfoVO> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserInfo::getAge, 20);
// 分页对象
Page<UserInfoVO> queryPage = new Page<>(page, limit);
// 分页查询
IPage<UserInfoVO> iPage = userInfoMapper.list(queryPage , queryWrapper);
// 数据总数
Long total = iPage.getTotal();
// 用户数据
List<UserInfoVO> list = iPage.getRecords();

以上就是分页查询(联表)时的操作,这个应该是用的比较多的

6、AND 和 OR

queryWrapper 默认是按照 and 来连接的,但是在我们业务需求中,肯定会用到 or 来写 SQL

  • 1、初级
    假设我们需要的 SQL 语句如下:
SELECTa.*
FROMuser_info a
WHERE1 = 1 AND a.id <> 1 AND ( a.`name` = 'jack' OR a.phone = '13888888888' )

那么我们可以这样写:

LambdaQueryWrapper<UserInfo> queryWrapper = new LambdaQueryWrapper<>();
// AND a.id <> 1
queryWrapper.ne(UserInfo::getId, "1");
// AND ( a.`name` = 'jack' OR a.phone = '13888888888' )
queryWrapper.and(i -> i.eq(UserInfo::getName, "jack").or().eq(UserInfo::getPhone, "13888888888"));
// 查询结果
List<UserInfo> list = userInfoMapper.selectList(queryWrapper);

以上就完成了初级的 and 和 or 联用的情况

  • 2、复杂
    假设我们需要的 SQL 语句如下:
SELECTa.*
FROMuser_info a
WHERE1 = 1 AND a.id <> 1 AND ( (a.`name` = 'jack' AND a.category = 1) OR (a.phone = '13888888888' OR a.category = 2) )

那么我们可以这样写:

LambdaQueryWrapper<UserInfo> queryWrapper = new LambdaQueryWrapper<>();
// AND a.id <> 1
queryWrapper.ne(UserInfo::getId, "1");
// AND ( (a.`name` = 'jack' AND a.category = 1) OR (a.phone = '13888888888' OR a.category = 2) )
queryWrapper.and(i -> (i.and(j -> j.eq(UserInfo::getName, "jack").eq(UserInfo::getCategory, 1))).or(j -> j.eq(UserInfo::getPhone, "13888888888").eq(UserInfo::getCategory, 2)));
// 查询结果
List<UserInfo> list = userInfoMapper.selectList(queryWrapper);

以上就完成了复杂的 and 和 or 联用的情况

那么以后遇见更复杂的,可以按此规则继续进行拼接 SQL

7、@TableLogic

这个注解是 Mybatis-Plus 的逻辑删除标志,一般注解在实体的属性上,假如我的用户信息表,用一个字段(del_flag)用来表示数据的删除状态,如下:

@ApiModelProperty(value = "删除状态(0--未删除1--已删除)")
@TableField("del_flag")
@TableLogic
private Integer delFlag;

Mybatis-Plus 默认使用 0 表示有效,1表示无效,当然也可以自定义,有两种方式:

  • 1、注解上
@ApiModelProperty(value = "删除状态(0--未删除1--已删除)")
@TableField("del_flag")
@TableLogic(value = "1", delval = "0")
private Integer delFlag;

value = “” 默认的原值,delval = “” 删除后的值

  • 2、配置文件
# mybatis配置
mybatis-plus:# 全局配置global-config:db-config:# 逻辑删除全局字段 (默认无 设置会自动扫描实体字段)logic-delete-field: delFlag# 逻辑删除全局值(默认 1、表示已删除)logic-delete-value: 1# 逻辑未删除全局值(默认 0、表示未删除)logic-not-delete-value: 0

那么,我们在查询数据的时候,会自动为我们加上查询条件

AND del_flag = 0

这时候逻辑删除生效,当我们执行 userInfoMapper.removeById(id) 时,也不会物理删除,实际执行的 SQL 如下:

UPDATE user_info set del_flag = 1 where id = #{id}

注意:自己在 xml 文件中写的 SQL 不会自动加上逻辑删除条件

7、指定查询字段(select)

当我们只需要查询表格中的某几个字段,如果表格数据很大的话,我们不应该查询表格的所有字段,假如,我们需要的 SQL 如下:

SELECTid,`name`,phone
FROMuser_info
WHERE1 = 1 AND age = 20

我们只需要查询年龄等于20的用户的 id、name、phone,所以,可以这样写

LambdaQueryWrapper<UserInfo> queryWrapper = new LambdaQueryWrapper<>();
// 只查询 id,name,phone
queryWrapper.select(UserInfo::getId, UserInfo::getName, UserInfo::getPhone);
// 查询条件为:age = 20
queryWrapper.eq(UserInfo::getAge, 20);
List<UserInfo> list = userInfoMapper.selectList(queryWrapper );

这样,我们就需要查询表中所有字段的数据,大大缩短了查询时间

8、查询一条数据(getOne)

getOne 是 service 中的方法,当我们使用 getOne 查询一条数据返回的时候,我们往往不是用主键 ID 去查询,如果用主键 ID 查询一条数据,我们应该使用:

UserInfo userInfo = userInfoService.getById(id);

假如我们用户表中有 openId 字段,例如:微信用户,这个肯定是唯一的,我们需要使用 openId 查询一条用户信息,我们通常使用:

LambdaQueryWrapper<UserInfo> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserInfo::getOpenId, openId);
UserInfo userInfo = userInfoService.getOne(queryWrapper);

但是这样存在一定的风险,也就是说如果表中存在同一个 openId 的两条及两条以上的数据时,会抛出异常,所以我们需要这样:

LambdaQueryWrapper<UserInfo> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserInfo::getOpenId, openId);
UserInfo userInfo = userInfoService.getOne(queryWrapper, false);

可以看出,传入了一个 false 参数,该参数的含义为:

  • 据 Wrapper,查询一条记录
  • 有多个 result 是否抛出异常

通过查看源码:

@Override
public T getOne(Wrapper<T> queryWrapper, boolean throwEx) {if (throwEx) {return baseMapper.selectOne(queryWrapper);}return SqlHelper.getObject(log, baseMapper.selectList(queryWrapper));
}

如果传入的是 true(默认值),则不作处理进行查询,否则进行分页查询,再看 getObject() 方法中:

/**
* 从list中取第一条数据返回对应List中泛型的单个结果
*
* @param list ignore
* @param <E>  ignore
* @return ignore
*/
public static <E> E getObject(Log log, List<E> list) {if (CollectionUtils.isNotEmpty(list)) {int size = list.size();if (size > 1) {log.warn(String.format("Warn: execute Method There are  %s results.", size));}return list.get(0);}return null;
}

默认取第一条数据返回,所以当我们查询为多条数据时,默认返回第一条

作者:Asurplus、
原文链接:https://lizhou.blog.csdn.net/article/details/108093246

free mybatis 不生效_这些Mybatis-Plus的使用小技巧,你应该知道的!相关推荐

  1. free mybatis 不生效_关于 Mybatis 设置懒加载无效的问题

    看了 mybatis 的教程,讲到关于mybatis 的懒加载的设置: 只需要在 mybatis 的配置文件中设置两个属性就可以了: 但是经过测试之后发现是无效的,经过一番折腾,发现是因为我在测试的时 ...

  2. 小程序禁止左右拖动_网课视频快进小技巧

    目前很多网课教程网站都是采取播放内嵌Flash视频课件进行教学的方式,且绝大部分屏蔽了视频快进(倍进)播放功能,只能等待整段视频缓冲完成后才可对视频时间轴进度条进行拖拽操作,加上网站课件视频缓冲速度较 ...

  3. 宝洁网测管道题技巧_宝洁笔试网测小技巧分享

    这里主要说三大部分,算术题.管道题和记忆题. ①算术题(digitChallenge): 所需资料:三乘表必备!!没有可以私聊我拿 注意事项:所填数字不能重复!拿真题练一下速度,清楚自己的强弱项.对我 ...

  4. case mybatis 不同表_解决mybatis case when 报错的问题

    在mybatis中使用case when进行条件筛选判断时遇到 Failed to process, please exclude the tableName or statementId. 这样的报 ...

  5. list mybatis 接收 类型_基于mybatis拦截器实现的一款简易影子表自动切换插件

    近期因工作需要,小编基于mybatis拦截器开发了一款简易影子表自动切换插件,可以根据配置实现动态修改表名,即将对原source table表的操作自动切换到对target table表的操作.该插件 ...

  6. keyshot怎么批量渲染_提高Keyshot逼真渲染的小技巧

    Keyshot是一个特别神奇的应用软件,但是,就像Photoshop一样,如果你不知道怎么使用它,那么再优秀的工具在你手中也什么都是了.这里我就告诉你一些制作优秀效果图的技巧以及如何使用这个神奇软件. ...

  7. 敲代码括号技巧_阅码神奇Souceinsight使用小技巧总结

    /****与SI的初遇****/ 对于大部分人第一次使用SI来说应该是对原IDE集成开发环境有很大的抱怨吧,确实我也一样,对于做嵌入式开发使用各种集成开发工具,比如说Keil,IAR等等,可能还有更加 ...

  8. cad 怎么显示块句柄_新手必看的CAD小技巧,老师傅精选汇总,三分钟教你学习用处多多...

    零基础新手必看的CAD绘图小技巧,这里分享给你,都是老师傅精选汇总,实实在在用得上,希望能够给你带去帮助! PS:其实CAD入门并不难,难在坚持,如果真的想要入这个行业,一定要你坚持哦! 废话不说了直 ...

  9. python获取当前目录_又有几个Python小技巧分享

    今天这篇文章为大家带来几个Python使用的小技巧: 快速生成依赖文件 文件路径处理 通过set将对象去重 单元测试unitest捕获异常 快速生成依赖文件 Python通过requirements. ...

最新文章

  1. 机器学习最常用的优化算法 — 梯度下降法
  2. Stacking+Blending
  3. mysql临时表是什么意思_来谈谈MySQL的临时表,到底是个什么东西,以及怎么样产生的...
  4. 【高级数据结构】[SPOJ QTREE]树链剖分/动态树各一模板
  5. 升技主板RAID磁盘阵列图解
  6. 【html、css、jq】制作一个简洁的音乐播放器
  7. inbound connection timed out (ORA-3136)错误诊断
  8. SQL2008 收缩日志和数据脚本
  9. C#lock语句用法(lock到底有什么用?)
  10. Redis数据存储解决方案
  11. 计算机控制系统的闭环复极点,计算机控制 第四章 2.ppt
  12. LDAP命令介绍---dstune
  13. ffmpeg获取视频截图
  14. 拓端tecdat:R语言KMEANS均值聚类和层次聚类:亚洲国家地区生活幸福质量异同可视化分析和选择最优聚类数
  15. IntelliJ IDEA 快捷键说明大全(中英对照、带图示详解)
  16. 需求跟踪矩阵和需求评审
  17. 2022华为春招面试经历
  18. 手机上怎样转变图片格式?教你一键快速转格式
  19. android TextView首行缩进两个字符
  20. Flask 和 requests 搭建一个简单的API服务

热门文章

  1. php红包平均分配,红包平均分配算法
  2. nginx ---- 启停
  3. asp.net三层架构制作新闻管理_程序员蜕变为架构师必须要知道的「架构理论」...
  4. base6 python 字节_Python使用base64模块进行二进制数据编码详解
  5. 地理信息-圆形、椭圆、扇形的表示方法及相关判断
  6. Rabbitmq消息过期时间设置
  7. c语言 __FILE__,__DATE__,__TIME__ (宏)
  8. php开发面试题---禁用cookie之后,如何使用session
  9. Java NIO问题总结
  10. Linux之bash脚本编程---if补充和for循环