MybatisPlus多條件?or()的使用問題小結(jié)
搞混了一次,特此筆記
1、bitCode or iotStr 跟其他ID一個都不能有重復(fù)
queryWrapper.ne(LineProductionPlan::getId,bean.getId()); queryWrapper.and(i -> i.eq(LineProductionPlan::getBitCode,bean.getBitCode()).or().eq(LineProductionPlan::getIotStr,bean.getIotStr()));
打印sql
2、模糊查詢codeOrName變量匹配二個字段
queryWrapper.lambda().and(StrUtil.isNotEmpty(codeOrName), i -> i.like(Point::getName, codeOrName).or().like(Point::getBitCode, codeOrName));
擴展:Mybatis-Plus中or()的使用避坑
1.連接 or()
當需要簡單的將兩個條件或連接,則最直接的寫法為:
QueryWrapper<User> queryWrapper = new QueryWrapper<User>(). eq("status",0). or(). eq("status",1); //sql條件為 select * from user where status=0 or status=1
2.連接 or()
當多個條件共同拼接,則最直接的寫法為: 要么把or()拼接放最前面,要么用queryWrapper.and(
qr.eq("status", 1).or().like("status", 2)),要不查詢的數(shù)據(jù)會有偏差,queryWrapper.and相當于把兩個條件()一塊;
QueryWrapper<User> queryWrapper = new QueryWrapper<User>(). eq("status",0). or(). eq("status",1) eq("user_name","張三"); //sql條件為 select * from user where status=0 or status=1 and user_name='張三' QueryWrapper<User> queryWrapper = new QueryWrapper<User>(). eq("user_name","張三"). eq("status",0). or(). eq("status",1); //sql條件為 select * from user where user_name='張三' and status=0 or status=1 查詢出來的數(shù)據(jù)和select * from user where status=0 or status=1 and user_name='張三' 不一致 QueryWrapper<User> queryWrapper = new QueryWrapper<User>(). eq("user_name","張三").and(q->q.eq("status",0). or(). eq("status",1)); select * from user where select * from user where user_name='張三' and (status=0 or status=1 ) 查詢出來的數(shù)據(jù)和select * from user where status=0 or status=1 and user_name='張三' 一致
到此這篇關(guān)于MybatisPlus多條件 or()的使用的文章就介紹到這了,更多相關(guān)MybatisPlus多條件 or()內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于SpringBoot整合oauth2實現(xiàn)token認證
這篇文章主要介紹了基于SpringBoot整合oauth2實現(xiàn)token 認證,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-01-01Java返回文件時為圖片或pdf等設(shè)置在線預(yù)覽或下載功能
這篇文章主要介紹了Java返回文件時為圖片或pdf等設(shè)置在線預(yù)覽或下載功能,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-01-01