在MyBatisPlus中使用or()和and()时常见的坑

在MyBatisPlus中使用or()和and()时常见的坑

在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 = &#63; AND status = &#63; OR file_size = &#63; 

写法二:

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 = &#63; AND ( status = &#63; OR file_size = &#63; )

SpringBoot 集成 MyBatisPlus 配置文件添加以下配置即可在控制台查看 sql

mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

关于在MyBatisPlus中使用or()和and()时常见的坑问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注行业资讯频道了解更多相关知识。