★条件构造器

迷人的老约翰 2021-06-25 02:06:05 22779 1 0 0

条件构造器wrapper

简介:
接口方法的参数中,会出现各种 Wrapper,比如 queryWrapper、updateWrapper 等。Wrapper 的作用就是用于定义各种各样的条件(where)。所以不管是查询、更新、删除都会用到Wrapper。

wrapper官方文档

注明:MybatisPlus的EntityWrapper,在3.0版本以上就没了,改为了QueryWrapper

常用比较方法

1.【比较大小: ( =, <>, >, >=, <, <= )】

eq(R column, Object val); // 等价于 =,例: eq("name", "🐂") ---> name = '🐂'
ne(R column, Object val); // 等价于 <>,例: ne("name", "🐂") ---> name <> '🐂'
gt(R column, Object val); // 等价于 >,例: gt("name", "🐂") ---> name > '🐂'
ge(R column, Object val); // 等价于 >=,例: ge("name", "🐂") ---> name >= '🐂'
lt(R column, Object val); // 等价于 <,例: lt("name", "🐂") ---> name < '🐂'
le(R column, Object val); // 等价于 <=,例: le("name", "🐂") ---> name <= '🐂'

2,范围查询

between(R column, Object val1, Object val2); // 等价于 between a and b, 例: between(“age”, 18, 30) —> age between 18 and 30
notBetween(R column, Object val1, Object val2); // 等价于 not between a and b, 例: notBetween(“age”, 18, 30) —> age not between 18 and 30
in(R column, Object… values); // 等价于 字段 IN (v0, v1, …),例: in(“age”,{1,2,3}) —> age in (1,2,3)
notIn(R column, Object… values); // 等价于 字段 NOT IN (v0, v1, …), 例: notIn(“age”,{1,2,3}) —> age not in (1,2,3)
inSql(R column, Object… values); // 等价于 字段 IN (sql 语句), 例: inSql(“id”, “select id from table where id < 3”) —> id in (select id from table where id < 3)
notInSql(R column, Object… values); // 等价于 字段 NOT IN (sql 语句)

3.模糊查询

like(R column, Object val); // 等价于 LIKE '%值%',例: like("name", "王") ---> name like '%王%'
notLike(R column, Object val); // 等价于 NOT LIKE '%值%',例: notLike("name", "王") ---> name not like '%王%'
likeLeft(R column, Object val); // 等价于 LIKE '%值',例: likeLeft("name", "王") ---> name like '%王'
likeRight(R column, Object val); // 等价于 LIKE '值%',例: likeRight("name", "王") ---> name like '王%'

空值比较

isNull / isNotNull

分组和排序

groupBy(R... columns); // 等价于 GROUP BY 字段, ..., 例: groupBy("id", "name") ---> group by id,name
orderByAsc(R... columns); // 等价于 ORDER BY 字段, ... ASC, 例: orderByAsc("id", "name") ---> order by id ASC,name ASC
orderByDesc(R... columns); // 等价于 ORDER BY 字段, ... DESC, 例: orderByDesc("id", "name") ---> order by id DESC,name DESC
having(String sqlHaving, Object... params); // 等价于 HAVING ( sql语句 ), 例: having("sum(age) > {0}", 11) ---> having sum(age) > 11

嵌套sql

wrapper 支持链式编程
查询

首先创建querywrapper
QueryWrapper wrapper = new QueryWrapper<>();

// 查询name不为空的用户,并且邮箱不为空的用户,年龄大于等于12
wrapper .isNotNull(“name”) .isNotNull(“email”) .ge(“age”,12)

//查询姓名
wrapper.eq(“name”,“狂神说”);

// 查询年龄在 20 ~ 30 岁之间的用户
wrapper.between(“age”,20,30); // 区间

// id 在子查询中查出来 子查询
wrapper.inSql(“id”,“select id from user where id<3”);

//// 通过id进行排序
wrapper.orderByAsc(“id”);

修改
@Test
public void testUpdateWrapper() {
    int reduceAge = 2;
    User user = new User();

    // 更新用户数据的wrapper
    UpdateWrapper<User> updateWrapper = new UpdateWrapper<User>();
    //修改数据的语句
    updateWrapper.set("email", "winspace@erbadagang.com");//使email字段的值更新为“winspace@erbadagang.com”
    updateWrapper.setSql("age = age - " + reduceAge);//自定义的sql语句
    //条件
    updateWrapper.eq("id", 4);
    userMapper.update(user, updateWrapper);
}
更多操作看官方文档:

https://mp.baomidou.com/guide/wrapper.html