关于EntityWrapper的in用法


Posted in Java/Android onMarch 22, 2022

EntityWrapper的in用法

EntityWrapper<UserLife> wrapper = new EntityWrapper<>();
wrapper.eq("is_valid", 1);
wrapper.in("life_name", "ge,edu,career");
List<UserLife> userLabelList = userLabelService.selectList(wrapper);

in的第二个参数可以是字符串也可以是list但是注意字符串中","间不能有空格,不然会查出来的语句就是这样的

关于EntityWrapper的in用法

mybatis-plus EntityWrapper in

环境:

springBoot+mybatis

源码:

        /**
     * <p>
     * IN 条件语句,目前适配mysql及oracle
     * </p>
     *
     * @param column 字段名称
     * @param value  匹配值 集合
     * @return this
     */
    public Wrapper<T> in(String column, Collection<?> value) {
        return in(true, column, value);
    }
    
    /**
     * <p>
     * IN 条件语句,目前适配mysql及oracle
     * </p>
     *
     * @param condition 拼接的前置条件
     * @param column    字段名称
     * @param value     匹配值 集合
     * @return this
     */
    public Wrapper<T> in(boolean condition, String column, Collection<?> value) {
        if (condition && CollectionUtils.isNotEmpty(value)) {
            sql.WHERE(formatSql(inExpression(column, value, false), value.toArray()));
        }
        return this;
    }

如果condition不传,等同于:condition: true;

如果传入的value不为空,相当于改 in 查询语句为拼接;

举个例子

    //代码
    @Override
    public List<User> selectByCaseIdSet(Set<String> idSet) {
        EntityWrapper<User> wrapper = new EntityWrapper<>();
        wrapper.in(!CollectionUtils.isEmpty(idSet), "id", idSet);
        return this.selectList(wrapper);
    }
/**
 * 如果idSet 为空,sql: select * from user 
 * 如果idSet 不为空, sql: select * from user where id in (idSet)
 ** /

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Java/Android 相关文章推荐
详解Java实践之建造者模式
Jun 18 Java/Android
Spring boot应用启动后首次访问很慢的解决方案
Jun 23 Java/Android
一篇文章带你复习java知识点
Jun 28 Java/Android
Spring Boot两种全局配置和两种注解的操作方法
Jun 29 Java/Android
SpringBoot工程下使用OpenFeign的坑及解决
Jul 02 Java/Android
spring cloud 配置中心客户端启动遇到的问题
Sep 25 Java/Android
Java实现给Word文件添加文字水印
Feb 15 Java/Android
Java 常见的限流算法详细分析并实现
Apr 07 Java/Android
Android开发之WECHAT微信小程序路由跳转的两种形式
Apr 12 Java/Android
解决spring.thymeleaf.cache=false不起作用的问题
Jun 10 Java/Android
Spring中bean集合注入的方法详解
Jul 07 Java/Android
app场景下uniapp的扫码记录
Jul 23 Java/Android
SpringBoot2零基础到精通之异常处理与web原生组件注入
Mar 22 #Java/Android
Java字符串逆序方法详情
Mar 21 #Java/Android
剑指Offer之Java算法习题精讲二叉树的构造和遍历
剑指Offer之Java算法习题精讲二叉树专项训练
InterProcessMutex实现zookeeper分布式锁原理
springboot+zookeeper实现分布式锁
Mybatis-Plus进阶分页与乐观锁插件及通用枚举和多数据源详解
Mar 21 #Java/Android
You might like
DOM基础及php读取xml内容操作的方法
2015/01/23 PHP
PHP接收json 并将接收数据插入数据库的实现代码
2015/12/01 PHP
基于Jquery插件开发之图片放大镜效果(仿淘宝)
2011/11/19 Javascript
jquery win 7透明弹出层效果的简单代码
2013/08/06 Javascript
js判断某个方法是否存在实例代码
2015/01/10 Javascript
使用 JavaScript 进行函数式编程 (一) 翻译
2015/10/02 Javascript
快速使用Bootstrap搭建传送带
2016/05/06 Javascript
ES6入门教程之let和const命令详解
2017/05/17 Javascript
vue-cli脚手架config目录下index.js配置文件的方法
2018/03/13 Javascript
深入浅析AngularJs模版与v-bind
2018/07/06 Javascript
angular2/ionic2 实现搜索结果中的搜索关键字高亮的示例
2018/08/17 Javascript
vue 点击按钮增加一行的方法
2018/09/07 Javascript
Javascript实现动态时钟效果
2018/11/17 Javascript
Python导入oracle数据的方法
2015/07/10 Python
Python实现八大排序算法
2016/08/13 Python
用Python将动态GIF图片倒放播放的方法
2016/11/02 Python
Python中生成器和迭代器的区别详解
2018/02/10 Python
Python实现使用卷积提取图片轮廓功能示例
2018/05/12 Python
解决python中 f.write写入中文出错的问题
2018/10/31 Python
python 将字符串完成特定的向右移动方法
2019/06/11 Python
Python函数生成器原理及使用详解
2020/03/12 Python
澳大利亚领先的男装零售连锁店:Lowes
2020/08/07 全球购物
TecoBuy澳大利亚:在线电子和小工具商店
2020/06/25 全球购物
我们在web应用开发过程中经常遇到输出某种编码的字符,如iso8859-1等,如何输出一个某种编码的字符串?
2014/03/30 面试题
汉语言文学毕业生求职信
2013/10/01 职场文书
计算机应用职专应届生求职信
2013/11/12 职场文书
通信工程专业毕业生推荐信
2013/12/25 职场文书
秘书专业自荐信范文
2013/12/26 职场文书
手术室护士长竞聘书
2014/03/31 职场文书
医院信息公开实施方案
2014/05/09 职场文书
后勤管理员岗位职责
2014/08/27 职场文书
银行转正自我鉴定
2014/09/29 职场文书
党委书记群众路线对照检查材料思想汇报
2014/10/04 职场文书
幼儿园辞职信
2015/05/13 职场文书
毕业答辩开场白范文
2015/05/27 职场文书
蓝天保卫战收官在即 :15行业将开展环保分级评价
2019/07/19 职场文书