Java8中LambdaQueryWrapper对象使用(学习笔记)

eq:

​ 说明:等于=

​ 例:

eq("name","老王")--------> name = '老王'
ne:

​ 说明:不等于<>

​ 例:

ne("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

​ 例:

isNull("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")--------> id 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("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",1))--------> and (name = '老王' and status <> 1)
apply:

​ 说明:拼接 SQL

​ 注意事项:该方法可用于数据库函数,动态入参的 params 对应前面 sqlHaving 内部的 {index} 部分,这样是不会有 SQL 注入风险的,反之会有!

​ 例:

apply("date_format(dateColumn,'%Y-%m-%d') = {0}","2021-08-08")--------> date_format(dateColumn,'%Y-%m-%d') = '2021-08-08'
last:

​ 说明:无视优化规则直接拼接到 SQL 的最后

​ 注意事项:只能调用一次,多次调用以最后一次为准,有 SQL 注入的风险,请谨慎使用

​ 例:

last("limit 1")
exists:

​ 说明:拼接 EXISTS ( SQL 语句 )

​ 例:

exists("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

​ 例:

nested(i -> i.eq("name","老王").ne("status",1))--------> (name = '老王' and status <> 1)
  • 3
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java是一种广泛使用的编程语言,有简单、面向对象、跨平台等特点。下面是Java学习的一些重要知识点和学习笔记: 1. Java基础: - 数据类型:Java提供了多种数据类型,包括基本数据类型和引用数据类型。 - 控制流程:学习如何使用条件语句(if-else、switch)、循环语句(for、while)等控制程序的流程。 - 数组:了解如何声明、初始化和操作数组。 - 方法:学习如何定义和调用方法,以及方法的参数和返回值。 - 类和对象:理解类和对象的概念,学习如何定义类、创建对象使用类的成员变量和方法。 - 继承和多态:掌握继承和多态的概念,了解如何使用继承创建子类,并实现方法的重写和多态的应用。 2. 面向对象编程: - 封装:学习如何使用访问修饰符(public、private、protected)来控制类的成员的访问权限。 - 继承:了解继承的概念和作用,学习如何使用extends关键字创建子类。 - 多态:理解多态的概念和实现方式,学习如何使用父类引用指向子类对象,实现方法的动态绑定。 3. 异常处理: - 异常的分类:了解异常的分类(Checked Exception和Unchecked Exception)和常见的异常类型。 - 异常处理机制:学习如何使用try-catch语句捕获和处理异常,以及使用throws关键字声明方法可能抛出的异常。 4. 输入输出: - 文件操作:学习如何读写文件,包括使用File类、字节流和字符流等。 - 序列化:了解对象的序列化和反序列化,学习如何将对象保存到文件或网络。 5. 集合框架: - 学习Java提供的集合框架,包括List、Set、Map等常用的集合类,以及它们的特点和用法。 6. 多线程编程: - 学习如何创建和管理线程,了解线程同步和线程间通信的方法。 7. 数据库连接: - 学习如何使用Java连接数据库,执行SQL语句,进行数据的增删改查操作。 以上是Java学习的一些重要知识点和学习笔记,希望对你有帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值