在项目中使用MyBatisPlus中的or()查询时由于误用,导致查询数据不对,仅作记录。
写法一:
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::getSta<strong style="color:transparent">本文来源gao@daima#com搞(%代@#码@网&</strong>tus, 2).or().eq(Task::getFileSize, 3251544304L));
上面这种写法对应的sql如下
SELECT * FROM task WHERE user_id = ? AND ( status = ? OR file_size = ? )
SpringBoot 集成 MyBatisPlus 配置文件添加以下配置即可在控制台查看 sql
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
总结
到此这篇关于MyBatisPlus中使用or()和and()遇到的问题的文章就介绍到这了,更多相关MyBatisPlus中使用or()和and()内容请搜索搞代码以前的文章或继续浏览下面的相关文章希望大家以后多多支持搞代码!