关于EntityWrapper的in用法
目录
- EntityWrapper的in用法
- mybatis-plus EntityWrapper in
- 举个例子
EntityWrapper的in用法
EntityWrapperwrapper = new EntityWrapper<>(); wrapper.eq("is_valid", 1); wrapper.in("life_name", "ge,edu,career"); List userLabelList = userLabelService.selectList(wrapper);
in的第二个参数可以是字符串也可以是list但是注意字符串中","间不能有空格,不然会查出来的语句就是这样的
文章图片
mybatis-plus EntityWrapper in 环境:
【关于EntityWrapper的in用法】springBoot+mybatis
源码:
/*** * IN 条件语句,目前适配mysql及oracle*
** @param column 字段名称* @param value匹配值 集合* @return this*/public Wrapperin(String column, Collection> value) {return in(true, column, value); }/*** * IN 条件语句,目前适配mysql及oracle*
** @param condition 拼接的前置条件* @param column字段名称* @param value匹配值 集合* @return this*/public Wrapperin(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 查询语句为拼接;
举个例子
//代码@Overridepublic ListselectByCaseIdSet(Set idSet) {EntityWrapper 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) ** /
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
推荐阅读
- Vue中父子组件通信与事件触发的深入讲解
- Java|Java 中的静态字段和静态方法
- MybatisPlus|MybatisPlus EntityWrapper如何自定义SQL
- Python中range、np.arange和np.linspace的区别
- C++ STL Merge的用法
- c++|虚函数和多态性
- Java|合格的Java工程师要掌握哪些知识点
- 算法|有关for(auto x: vector<int>v)的问题
- #|【EB_Tresos专题】-11.2-如何手动配置一个Rx接收的CAN Frame
- PTA|本题要求编写程序,以hh:mm:ss的格式输出某给定时间再过n秒后的时间值(超过23:59:59就从0点开始计时)。