QueryWrapper中查詢的坑及解決
更新時間:2022年01月11日 10:27:37 作者:香豬腳
這篇文章主要介紹了QueryWrapper中查詢的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。
QueryWrapper中查詢的坑
首先,先看代碼示例
List<Entity> list = testService.list(
? ? ? ? ? ? ? ? ? ? new LambdaQueryWrapper<Entity>()
? ? ? ? ? ? ? ? ? ? ? ? ? ? .eq(ObjectUtils.isNotEmpty(req.getParam()),Entity::getParam,
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? req.getParam().substring(0,7).replace("-",""))
);正常邏輯,當ObjectUtils.isNotEmpty(req.getParam())為false的時候,所執(zhí)行的SQL不會出現當前條件的字段;
然而,這種寫法如果當req.getParam()為""的時候,程序會出現數組下標越界的錯誤,雖然前面條件未成立,但是后面的代碼依然編譯執(zhí)行;
此處是本猿自己工作中遇到的一些小問題,發(fā)表出來,以便記錄,也給路過的伙伴提個醒。
QueryWrapper的查詢方法
Wrapper: 條件構造抽象類,最頂端父類AbstractWrapper: 用于查詢條件封裝,生成 sql 的 where 條件QueryWrapper: Entity 對象封裝操作類,不是用lambda語法UpdateWrapper: Update 條件封裝,用于Entity對象更新操作AbstractLambdaWrapper: Lambda 語法使用 Wrapper統(tǒng)一處理解析 lambda 獲取 column。LambdaQueryWrapper: 看名稱也能明白就是用于Lambda語法使用的查詢WrapperLambdaUpdateWrapper: Lambda 更新封裝Wrapper
QueryWrapper
@Test
? ? public void squery() {
? ? ? ? //創(chuàng)建QueryWrapper 對象
? ? ? ? QueryWrapper<User> queryWrapper = new QueryWrapper<>();
? ? ? ? //ge gt le lt: 大于等于 大于 小于等于 小于
? ? ? ? queryWrapper.ge("age",29);
? ? ? ? List<User> users = userMapper.selectList(queryWrapper);
? ? ? ? System.out.println(users);
? ? ? ??
? ? ? ? //eq ne ?等于 不等于
? ? ? ? //between 介于查詢
? ? ? ? queryWrapper.between("age",28,30);
? ? ? ? List<User> users1 = userMapper.selectList(queryWrapper);
? ? ? ? System.out.println(users1);
? ? ? ??
? ? ? ? //模糊查詢
? ? ? ? queryWrapper.like("nam","l");
? ? ? ? queryWrapper.select("id","nam");
? ? ? ? List<User> users2 = userMapper.selectList(queryWrapper);
? ? ? ? System.out.println(users2);
? ? ? ??
? ? ? ? // orderByDesc 降序查找
? ? ? ? queryWrapper.orderByDesc;
? ? ? ??
? ? ? ? //last 在sql語句后面拼接
? ? ? ? queryWrapper.last("limit 1");
? ? }以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
IDEA工程運行時總是報xx程序包不存在實際上包已導入(問題分析及解決方案)
這篇文章主要介紹了IDEA工程運行時,總是報xx程序包不存在,實際上包已導入,本文給大家分享問題分析及解決方案,通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2020-08-08
SpringBoot中@ConfigurationProperties自動獲取配置參數的流程步驟
當需要獲取配置文件中很多參數時,我們可以定義參數的前綴相同,通過自動映射 進行獲取配置文件中參數,所以本文給大家介紹了SpringBoot中@ConfigurationProperties自動獲取配置參數的流程步驟,需要的朋友可以參考下2024-11-11
SpringCloud使用Feign實現動態(tài)路由操作
這篇文章主要介紹了SpringCloud使用Feign實現動態(tài)路由操作,文章圍繞主題展開詳細的內容介紹具有一定的參考價值,需要的小伙伴可以參考一下2022-06-06

