Mybatis-plus LambdaQueryWrapper 模糊查詢方法使用記錄

https://blog.csdn.net/qq_33651286/article/details/125653634

項目開發(fā)過程中使用Mybatis-Plus的lambda 表達式假残,對其中對模糊查詢like方法開始不理解其中參數Boolean是什么作用缭贡。后邊看其他的方法都是兩個對應的,有帶Boolean參數的有不帶的辉懒。查閱資料得知:

代碼如下:

//條件封裝

QueryWrapper<FykUser> queryWrapper = new QueryWrapper<>();

queryWrapper.like(StringUtils.isNotBlank(user.getName()), "NAME", user.getName());

queryWrapper.like(user.getEnable() != null, "ENABLE", user.getEnable());

List<FykUser> userList = userDao.selectList(queryWrapper);

這里阳惹,like方法有三個參數:

第一個參數:該參數是一個布爾類型,只有該參數是true時眶俩,才將like條件拼接到sql中莹汤;本例中,如果name字段不為空颠印,則拼接name字段的like查詢條件纲岭;

第二個參數:該參數是數據庫中的字段名;

第三個參數:該參數值字段值嗽仪;

需要說明的是荒勇,這里的like查詢是使用的默認方式,也就是說在查詢條件的左右兩邊都有%:NAME = ‘%王%'闻坚;

如果只需要在左邊或者右邊拼接%沽翔,可以使用likeLeft或者likeRight方法。

其他

在QueryWrapper類中,可以看到仅偎,還有很多條件查詢的方法跨蟹,諸如ge、le橘沥、lt窗轩、between等之類的方法,他們的傳參方式都和上面介紹的差不多座咆。

對于上面的理解痢艺,給出代碼示例:

wrapper.lambda().like(Objects.nonNull(roleId), SysRoleResource::getRoleId, roleId);//----對應SQL:role_id like ‘%1%’

wrapper.lambda().likeLeft(Objects.nonNull(roleId), SysRoleResource::getRoleId, roleId);//----對應SQL:role_id like ‘%1’

wrapper.lambda().likeRight(Objects.nonNull(roleId), SysRoleResource::getRoleId, roleId);//----對應SQL:role_id like ‘1%’

換個寫法解釋第一個參數:

if (roleId != null) {

?wrapper.lambda().like(SysRoleResource::getRoleId, roleId);?

}

擴展:

queryWrapper.lt()——小于

queryWrapper.le()——小于等于

queryWrapper.gt()——大于

queryWrapper.ge()——大于等于

queryWrapper.eq()——等于

queryWrapper.ne()——不等于

queryWrapper.betweeen(“age”,10,20)——age在值10到20之間

queryWrapper.notBetweeen(“age”,10,20)——age不在值10到20之間

queryWrapper.like(“屬性”,“值”)——模糊查詢匹配值‘%值%’

queryWrapper.notLike(“屬性”,“值”)——模糊查詢不匹配值‘%值%’

queryWrapper.likeLeft(“屬性”,“值”)——模糊查詢匹配最后一位值‘%值’

queryWrapper.likeRight(“屬性”,“值”)——模糊查詢匹配第一位值‘值%’

queryWrapper.isNull()——值為空或null

queryWrapper.isNotNull()——值不為空或null

queryWrapper.in(“屬性”,條件介陶,條件 )——符合多個條件的值

queryWrapper.notIn(“屬性”堤舒,條件,條件 )——不符合多個條件的值

queryWrapper.or()——或者

queryWrapper.and()——和

queryWrapper.orderByAsc(“屬性”)——根據屬性升序排序

queryWrapper.orderByDesc(“屬性”)——根據屬性降序排序

queryWrapper.inSql(“sql語句”)——符合sql語句的值

queryWrapper.notSql(“sql語句”)——不符合SQL語句的值

queryWrapper.esists(“SQL語句”)——查詢符合SQL語句的值

queryWrapper.notEsists(“SQL語句”)——查詢不符合SQL語句的值

?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末哺呜,一起剝皮案震驚了整個濱河市舌缤,隨后出現的幾起案子,更是在濱河造成了極大的恐慌某残,老刑警劉巖国撵,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異玻墅,居然都是意外死亡介牙,警方通過查閱死者的電腦和手機,發(fā)現死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進店門椭豫,熙熙樓的掌柜王于貴愁眉苦臉地迎上來耻瑟,“玉大人,你說我怎么就攤上這事赏酥。” “怎么了谆构?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵裸扶,是天一觀的道長。 經常有香客問我搬素,道長呵晨,這世上最難降的妖魔是什么闽坡? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任愚臀,我火速辦了婚禮夯缺,結果婚禮上刁品,老公的妹妹穿的比我還像新娘掖棉。我一直安慰自己咙边,他們只是感情好狐粱,可當我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布拒啰。 她就那樣靜靜地躺著,像睡著了一般胯舷。 火紅的嫁衣襯著肌膚如雪刻蚯。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天桑嘶,我揣著相機與錄音炊汹,去河邊找鬼。 笑死逃顶,一個胖子當著我的面吹牛讨便,可吹牛的內容都是我干的。 我是一名探鬼主播以政,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼器钟,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了妙蔗?” 一聲冷哼從身側響起傲霸,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎眉反,沒想到半個月后昙啄,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡寸五,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年梳凛,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片梳杏。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡韧拒,死狀恐怖,靈堂內的尸體忽然破棺而出十性,到底是詐尸還是另有隱情叛溢,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布劲适,位于F島的核電站楷掉,受9級特大地震影響,放射性物質發(fā)生泄漏霞势。R本人自食惡果不足惜烹植,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望愕贡。 院中可真熱鬧草雕,春花似錦、人聲如沸固以。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至败晴,卻和暖如春浓冒,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背尖坤。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工稳懒, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人慢味。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓场梆,卻偏偏與公主長得像,于是被迫代替她去往敵國和親纯路。 傳聞我的和親對象是個殘疾皇子或油,可洞房花燭夜當晚...
    茶點故事閱讀 44,577評論 2 353

推薦閱讀更多精彩內容