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
0
投稿
猜你喜欢
- 云计算、大数据地快速发展催生了不少热门的应用及工具。作为老牌语言Java,其生态圈也出来了一些有关云服务、监控、文档分享方面的工具。本文总结
- 现在很多的网站都提供有用户注册功能, 通常我们注册成功之后就会收到一封来自注册网站的邮件。邮件里面的内容可能包含了我们的注册的用户名和密码以
- 前言前天工作中遇到了这样一个问题,我在接口的参数封装了一个pojo,这是很常见的,当参数一多,惯性的思维就是封装一个pojo.那么在参数前有
- 前言回想一下,在学Java时接触的正则表达式,其实Kotlin中也是类似。只不过使用Kotlin 的语法来表达,更为简洁。正则(Regex)
- 本文实例为大家分享了java实现航空用户管理系统的具体代码,供大家参考,具体内容如下题目内容:某航空公司在其航班到达的不同的国家的不同地方设
- 利用栈实现一个简易计算器(Java实现),供大家参考,具体内容如下一、思路分析当我们输入一个类似于“7*2+100-5+
- 引言: 在Spring Boot应用中,基于数据某个字段进行排序是一个非常常用的需求,这里将给出Sort的三种常用用法,基于分页的应用,大家
- 本文实例为大家分享了Android登录注册功能的具体代码,供大家参考,具体内容如下展示效果代码区MainActivity(登录方法)publ
- dom4j是一个非常优秀的Java XML API,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源工具。可以在这个地址ht
- 事件处理主要涉及:事件源,事件,事件处理者在GUI中事件源是事件发生的场所,通常是各个组件,如被单击的按钮;事件是用户对界面的操作,如操作键
- 1、Java版package com.lyz.utils.common; import java.io.UnsupportedEncodin
- 0-1背包的问题背包问题(Knapsack problem)是一种组合优化的NP完全问题。问题可以描述为:给定一组物品,每种物品都有自己的重
- 最近做一个需求,需求中的bean只用于生成一次json使用,所以想通过配置来动态的生成,查了一下,java还真有这个实现。java动态的生成
- 懒加载---就是我们在spring容器启动的是先不把所有的bean都加载到spring的容器中去,而是在当需要用的时候,才把这个对象实例化到
- @Configuration注解的类:/** * @Description 测试用的配置类 * @Author 弟中弟 * @CreateT
- FTP(File Transfer Protocol)就是文件传输协议。通过FTP客户端从远程FTP服务器上拷贝文件到本地计算机称为下载,将
- 1.Java进程的创建 Java提供了两种方法用来启动进程或其它程序: (1)使用Runtime的exec()方法 (2)使用Process
- SqlMapConfig.xml的约束,也就是Mybatis主配置文件的约束<?xml version="1.0"
- 引言在项目中,时间的使用必不可少,而java 8之前的时间api Date和Calander等在使用上存在着很多问题,于是,jdk1.8引进
- JAVA中Integer类下的常用方法有哪些?1.进制转换 n进制转10进制 字符串结果Integer.parseInt(String s,