真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

or與and在MyBatisPlus中使用的區(qū)別有什么-創(chuàng)新互聯(lián)

or與and在MyBatis Plus中使用的區(qū)別有什么?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

為敦化等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及敦化網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè)、敦化網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!

最近在使用MyBatis Plus,發(fā)現(xiàn)在拼接條件的時候,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 = ?)

這樣子是肯定不行的,于是去官網(wǎng)查詢,發(fā)現(xiàn)正確的寫法是這樣的

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 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));
  }

對應(yīng)打印的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)

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

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

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,的支持。


網(wǎng)站名稱:or與and在MyBatisPlus中使用的區(qū)別有什么-創(chuàng)新互聯(lián)
分享路徑:http://weahome.cn/article/cojigj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部