mybatisPlus条件构造器常用方法小结
作者:Wmenghu 发布时间:2023-12-16 07:04:09
标签:mybatisPlus,条件,构造器
首先是.select
在MP查询中,默认查询所有的字段,如果有需要也可以通过select方法进行指定字段。其中要注意的细节:
wrapper.select("pname")
.eq("pname","张三")
.or().eq("price",300);
List<User> userList = userDao.selectList(wrapper);
使用select进行sql语句拼接时,不会识别在实体类中属性对应的操作:
SELECT pname FROM USER WHERE (pname = ? or price =? )
当数据库表中的字段名,与实体类对象的属性名不一致时
wrapper.select("pname as name")
.eq("pname","张三")
.or().eq("price",300);
List<User> userList = userDao.selectList(wrapper);
这样拼接出来的sql语句:
SELECT pname as name FROM user WHERE (pname = ? OR price = ? )
其他条件
函数名 | 说明 | 例子 |
eq | 等于 = | 例:eq(“name”,“张三”) :name = ‘张三’ |
ne | 不等于<> | 例: eq(“name”,“老王”) —> name <> ‘老王’ |
gt | 大于> | 例:gt(“age”,18) —> age > 18 |
ge | 大于等于>= | 例:ge(“age”,18) —> age >= 18 |
lt | 小于< | 例:lt(“age”,18) —> age < 18 |
le | 小于<= | 例:le(“age”,18) —> age <= 18 |
between | BETWEEN值1 AND值2 | 例:between(“age”,18,30) —> age between 18 and 30 |
notBetween | NOT BETWEEN值1 AND值2 | 例: notBetween(“age”,18,30) —> age not between 18 and 30 |
like | LIKE ‘%值%’ | 例: like(“name”,“王”) —–> name like '%王%’ |
notLike | NOT LIKE ‘%值%’ | 例: notLike (“name”,“王”) —> name not like '%王%’ |
likeLeft | LIKE '%值’ | 例:likeLeft (“name”,“王”) —–> name like '%王’ |
likeRight | LIKE’值%’ | 例: likeRight(“name”,“王”) —> name like ‘王%’ |
isNull | 字段IS NULL | 例: isNul1 (“name”) —> name is null |
isNotNull | 字段IS NOT NULL | 例: isNotNull(“name”) —> name is not null |
in | 字段IN (v0, v1,…) | 例: in(“age”,{1,2,3} ) —–> age in (1,2,3) |
notIn | 字段NOT IN (v0, v1,…) | 例: notIn(“age”,1,2,3) —> age not in (1,2,3) |
inSql | 字段IN ( sql语句) | inSql(“id”, “select id from table where id < 3”) —–> id in (select id from table where id < 3) |
notInSql | 字段NOT IN ( sql语句) | notInSql(“id”, “select id from table where id < 3”) —–> age not in (select id from table where id < 3) |
groupBy | 分组:GROUP BY 字段,… | 例: groupBy(“id”, “name”) —> group by id, name |
orderByAsc | 排序:ORDER BY字段,… ASC | 例: orderByAsc(“id”, “name”) —> order by id ASC, name ASC |
orderByDesc | 排序:ORDER BY 字段,…DESC | 例: orderByDesc(“id”, “name”) —> order by id DESC, name DESC |
orderBy | 排序:ORDER BY字段,… | 例: orderBy(true,true,“id”,“name”) —–> order by id ASC,name ASC |
having | HAVING ( sql语句) | having(“sum(age) >{0}”,11) —> having sum(age) > 11 |
or | 拼接OR | 主动调用or表示紧接着下一个方法不是用and连接!(不调用or则默认为使用and连接)例:eq(“id”,1).or().eq(“name”,“老王”) —> id = 1 or name = '老王 |
and | AND嵌套 | 例: and(i -> i.eq(“name”,“李白”).ne(“status”,“活着”)) —> and (name ='李白’ and status ’活着’) |
apply | 拼接sql | 该方法可用于数据库函数动态入参的params对应前面sqlHaving内部的{index}部分.这样是不会有sql注入风险的,反之会有! 例: apply(“date_format(dateColumn, ‘%Y一%m-%d’) ={0}”, “2008-08-08”) —> date_format(dateColumn,’%Y一%m-%d’) = ‘2008-08-08’") |
last | 无视优化规则直接拼接到sql 的最后 | 无视优化规则直接拼接到sql 的最后只能调用一次,多次调用以最后一次为准有sql注入的风险,请谨慎使用例: last(“limit 1”) |
exists | 拼接EXISTS ( sql语句) | —> exists (select id from table where age = 1)例: notExists(“select id from table where age = 1”) —>exists (select id from table where age = 1) |
notExists | 拼接NOT EXISTS ( sql语句) | 例: notExists(“select id from table where age = 1”) —–> not exists (select id from table where age = 1) |
nested | 正常嵌套不带AND或者 OR | 正常嵌套不带AND或者OR例: nested(i -> i.eq(“name”,“李白”).ne(“status”,“活着”)) —> (name = '李白’and status 活着’) |
来源:https://blog.csdn.net/w13966597931/article/details/127412114


猜你喜欢
- Spring Boot整合Spring Data JPA1)加入依赖<dependency> <groupId
- 在Android游戏开发中,我们可能经常要像PC操作一样在屏幕上双击。对于屏幕双击操作,Android 1.6版本以前并没有提供完善的手势识
- Spring 表达式语言简称为 SpEL,一种类似 Ognl 的对象图导航语言(对于 ognl 不熟悉的同学可以参考一下: Ognl 系列博
- java8的stream流能完美解对象集合去重问题. List<UserCar> list1 = new ArrayList()
- 前言大家都知道,不少仪器工作站可xls文件和2007+的xl以将数据导出为Excel文件,包括97-2003版本的sx文件。采集Excel文
- 这是主要使用到的jar 文件是:spring mvc +apache common-fileuplad第一步:web.xml 文件。【重点是
- Bezier Curve算法是根据参数曲线方程来得到光滑曲线的一种算法,曲线方程的参数由控制点决定。其本质是由调和函数根据控制点插值而成,其
- 异常和异常处理C# 语言的异常处理功能可帮助您处理程序运行时出现的任何意外或异常情况。异常处理使用 try、catch 和 finally
- WebService是一个SOA(面向服务的编程)的架构,它是不依赖于语言,不依赖于平台,可以实现不同的语言间的相互调用,通过Interne
- 定义:使多个对象都有机会处理请求,从而避免了请求的发送者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有对象处理
- Starting创建手势密码可以查看 CreateGestureActivity.java 文件.登陆验证手势密码可以看 GestureLo
- 大二的时候做的课程设计,图片管理器,当时遇到图片很多的文件夹,加载顺序非常慢。虽然尝试用多个Thread加载图片,却无法保证图片按顺序加载。
- 提示:java.util.zipoutputstream
- 在混淆编译之前,我的程序可以正常运行,混淆编译时,报告如下错误: Error:Execution failed for task ‘:gvi
- 一、 HttpURLConnection以GET方式访问网络:HttpURLConnection connection = null;try
- 字符串操作在任意编程语言的日常编程中都随处可见,今天来汇总一下 C# 中关于字符串的一些你可能遗忘或遗漏的知识点。逐字字符串在普通字符串中,
- 一、什么是特性特性(Attribute)是用于在运行时传递程序中各种元素(比如类、方法、结构、枚举、组件等)的行为信息的声明性标签。您可以通
- 前言:发送邮件,肯定是每个公司都会有的基本业务。很多公司都会选择把发送邮件作为一个基础服务,对外提供接口。直接调用就可发邮件了。但是我们都知
- 工程加入依赖:<dependency><groupId>org.apache.pdfbox</groupId&
- 今天看到已经更新了devblogs,新增的C# 11的!!(用于检查null的语法)经过非常长的讨论,最后取消了。然后我又想起来null检查