一、MyBatisPlus中使用or()和and()遇到的问题及细节处理
写法一:
LambdaQueryWrapper<Task> queryWrapper = new QueryWrapper<Task>().lambda();
queryWrapper
.eq(Task::getUserId, "15")
.eq(Task::getStatus, 2)
.or()
.eq(Task::getFileSize, 3251544304L);
上面这种写法等价于下面的sql
SELECT * FROM task WHERE user_id = ? AND status = ? OR file_size = ?
写法二:
LambdaQueryWrapper<Task> queryWrapper2 = new QueryWrapper<Task>().lambda();
queryWrapper2
.eq(Task::getUserId, "15")
.and(wrapper -> wrapper.eq(Task::getStatus, 2).or().eq(Task::getFileSize, 3251544304L));
上面这种写法对应的sql如下
SELECT * FROM task WHERE user_id = ? AND ( status = ? OR file_size = ? )
二、Mybatis Plus 更新update操作
1、根据ID更新 updateById
@Test
void updateTest(){
User user = new User();
user.setId(19); //查询id的条件
user.setRole("updateTest"); //更新字段的值
System.out.println(userDao.updateById(user));
//返回int类型,这里修改的是一条,返回1就是成功了,如果修改多条,就返回多少个数量,
//如果返回的是0表示没有搜索到这条数据,修改不成功。
}
}
2、根据条件更新update
方式1:使用QueryWrapper 操作
@Test
void updateTest(){
User user = new User();
user.setRole("updatewhere"); //更新的字段
// Query对象,用于设置条件,传User实体
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.eq("role","asdf"); // 设置查询条件
userDao.update(user, wrapper);
}
方式2:使用UpdateWrapper操作(推荐)
@Test
void updateTest2(){
//UpdateWrapper更新操作
UpdateWrapper<User> warp = new UpdateWrapper<>();
//通过set设置需要修改的内容,eq设置条件
warp.set("pwd","warpper").set("token","warptoken").eq("user","zyh4");
System.out.println(userDao.update(null,warp));
}
三、Mybatis Plus 聚合函数 MAX() 操作
QueryWrapper<RmIndexTypeInfo> wrapper = new QueryWrapper<>();
wrapper.eq("VC_ANALYSOBJ_ID", vcAnalysobjId)
.isNotNull("VC_INDEX_TYPE_PID")
.eq("VC_INDEX_TYPE_PID", vcIndexTypePid)
.select("nvl(MAX(L_SORT),0) AS NODESXH");
Map<String, Object> map = this.getMap(wrapper);
Integer nodeSxh = map.get("NODESXH") == null ? 0 : Integer.valueOf(String.valueOf(map.get("NODESXH")));