国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

關于MyBatis Plus中使用or和and問題

瀏覽:235日期:2023-10-20 15:07:52

最近在使用MyBatis Plus,發現在拼接條件的時候,and和or會出問題,比如下面這種

QueryWrapper userWrapper = new QueryWrapper();userWrapper.eq(“name”, name); userWrapper.eq(“pwd”,pwd).or().eq(“phone”, phone);

這種寫法拼出來的SQL語句是這樣的:

select * from user where (name = ? and pwd= ? or phone = ?)

這樣子是肯定不行的,于是去官網查詢,發現正確的寫法是這樣的

QueryWrapper userWrapper = new QueryWrapper();userWrapper.eq(“name”, name); userWrapper.and(wrapper ->wrapper.eq(“pwd”, pwd).or().eq(“phone”, phone));

select * from user where name = ? and ( pwd= ? or phone = ?)

補充:MyBatisPlus中and與or的連用

QueryWrapper<User> userWrapper = new QueryWrapper<>(); String type = (String) map.get('type'); if(StringUtils.isNotBlank(type)) { userWrapper.eq('is_admin', 'admin'.equals(type) ? true : false); } String keys = (String) map.get('key'); if(StringUtils.isNotBlank(keys)) { userWrapper.and(wrapper -> wrapper.like('login_name', keys).or().like('tel', keys).or().like('email', keys)); }

對應打印的SQL語句為:

SELECT id, login_name AS loginName, is_admin AS adminUser, ... del_flag AS delFlag, remarks FROM sys_user WHERE is_admin = 0 AND ( login_name LIKE ’%j%’ OR tel LIKE ’%j%’ OR email LIKE ’%j%’ )

注意:

userWrapper.and(…)中的and為后面的條件加上了括號,如果沒有and(),直接使用

userWrapper.like('login_name', keys).or().like('tel', keys).or().like('email', keys)

這一部分對應的SQL語句是不會被括號包圍的(若使用or(…),同理);

2. and(…)中的wrapper -> wrapper,注意名稱需要相同。

到此這篇關于關于MyBatis Plus中使用or和and問題的文章就介紹到這了,更多相關MyBatis Plus使用or和and內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 南华县| 甘泉县| 砀山县| 福海县| 凌云县| 沙雅县| 米林县| 句容市| 景德镇市| 克什克腾旗| 仙桃市| 锡林郭勒盟| 龙泉市| 北辰区| 聂拉木县| 永寿县| 嘉祥县| 龙游县| 罗城| 昭通市| 宁陵县| 抚宁县| 平山县| 灯塔市| 凯里市| 呼图壁县| 贡嘎县| 申扎县| 河北省| 金平| 安多县| 阳东县| 泗洪县| 皋兰县| 连州市| 美姑县| 名山县| 嘉祥县| 安塞县| 双江| 昆山市|