电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

關于mybatis plus 中的查詢優化問題

瀏覽:4日期:2023-10-20 10:33:23

傳統的mybatis plus 查詢寫法

對于常規的mybatis單表查詢,我們既可以采用LambdaQueryWrapper查詢,也可以使用QueryWrapper查詢。LambdaQueryWrapper具有防誤寫、規范代碼等好處,但是缺點是無法在復雜的多表查詢中使用。相比較來說,使用QueryWrapper編寫查詢更加靈活,可以適應更復雜的查詢場景。我們首先看一個QueryWrapper查詢的例子

public List<UserMo> list (UserForm userForm) { QueryWrapper<UserMo> queryWrapper = new QueryWrapper<>(); queryWrapper.like(StringTool.isNotEmpty(userForm.getUserName(), 'name', userForm.getUserName()); queryWrapper.eq(StringTool.isNotEmpty(userForm.getMobile(), 'mobile', userForm.getMobile()); // 其它的查詢條件... return userMapper.selectList(queryWrapper);}

對于上面的查詢語句來說,可以很好的對前端傳值進行處理,當userForm中有前端傳值的話,就會往SQL語句中加一條where條件。但是這樣做的話會有一個相對來說比較復雜的點,那就是當UserForm中的字段過于多的時候,我們也許得寫十幾行的這種重復判斷的語句。

通過自定義注解來解決通用查詢條件過多問題

通過觀察mybatis plus 對于queryWrapper相關查詢方法的列子,我們可以找出一類通用方法

關于mybatis plus 中的查詢優化問題

可以看出來這幾個方法都是傳的同樣的三個參數。我想對于這些簡單的通用的查詢條件,也許可以有一個通用的方法來填充。我首先設置了一個枚舉類,將這些查詢條件列出來,并在構造方法中,將對應的方法以反射的方式取到。

public enum QueryConditionEnum { EQ('eq'), NE('ne'), GT('gt'), GE('ge'), LT('lt'), LE('le'), LIKE('like'), NOT_LIKE('notLike'), LIKE_LEFT('likeLeft'), LIKE_RIGHT('likeRight'); private String name; private Method method; QueryConditionEnum (String name) { this.name = name; try { Method method = AbstractWrapper.class.getDeclaredMethod(name, boolean.class, Object.class, Object.class); this.method = method; } catch (NoSuchMethodException e) { } } }

再者,我想通過注解的方式來規定需要以什么方法填充,默認為EQ,對此寫了一個QueryCondition注解。

@Retention(RetentionPolicy.RUNTIME)@Target({ElementType.FIELD})public @interface QueryCondition { /** * 默認查詢方式 * * @return */ QueryConditionEnum value() default QueryConditionEnum.EQ; /** * 是否填充默認查詢條件 * * @return */ boolean isCondition() default true; }

然后就可以這樣構造UserForm

public class UserForm { private String name; @QueryCondition(QueryConditionEnum.LIKE) private String mobile;}

我們需要一個工具類填充查詢條件,這里我們新增了一個參數 mo對象,這是因為我們的主查詢對象是Mo對象,Mo對象存儲了相關表格名稱、表格字段名信息。

@TableName('user')public class UserMo { @TableField('name') private String name; @TableField('mobile') private String mobile;}

public class QueryTool { /** * 填充默認查詢 * @param baseClazz mo對象class * @param queryWrapper 查詢條件 * @param form 請求對象 */ public static void paddingDefaultConditionQuery(Class baseClazz, QueryWrapper queryWrapper, Object form) { try { for (Field declaredField : form.getClass().getDeclaredFields()) { declaredField.setAccessible(true); Object fieldValue = declaredField.get(form); QueryCondition queryCondition = declaredField.getAnnotation(QueryCondition.class); if (fieldValue == null) { continue; } if (queryCondition == null) { queryWrapper.eq(StringTool.isNotEmpty(fieldValue.toString()), QueryTool.getTableName(baseClazz) + '.' + QueryTool.getTableFieldName(baseClazz, declaredField), fieldValue.toString()); continue; } if (queryCondition.isCondition() == false) { continue; } Method method = queryCondition.value().getMethod(); method.invoke(queryWrapper, StringTool.isNotEmpty(fieldValue.toString()), QueryTool.getTableName(baseClazz) + '.' + QueryTool.getTableFieldName(baseClazz, declaredField), fieldValue.toString()); } } catch (Exception e) { throw new RuntimeException('填充默認的SQL條件出錯', e); } } /** * 填充默認排序 * * @param queryWrapper * @param pageForm */ public static void paddingDefaultOrderQuery(QueryWrapper queryWrapper, PageForm pageForm) { queryWrapper.orderBy(pageForm != null && StringTool.isNotEmpty(pageForm.getColumnName()), pageForm.getIsAsc() == null ? false : pageForm.getIsAsc(), pageForm.getColumnName()); } /** * 獲取表名稱 * * @return */ public static String getTableName(Class baseClazz) { TableName tableName = (TableName) baseClazz.getDeclaredAnnotation(TableName.class); if (tableName != null && StringTool.isNotEmpty(tableName.value())) { return tableName.value(); } return StringTool.toUnderline(baseClazz.getClass().getName()); } /** * 獲取字段名 * * @param field * @return */ public static String getTableFieldName(Class baseClazz, Field field) { Field baseField = null; try { baseField = baseClazz.getDeclaredField(field.getName()); } catch (NoSuchFieldException e) { e.printStackTrace(); } if (baseField == null) { baseField = field; } TableId tableId = baseField.getAnnotation(TableId.class); if (tableId != null && StringTool.isNotEmpty(tableId.value())) { return tableId.value(); } TableField tableField = baseField.getAnnotation(TableField.class); if (tableField != null && StringTool.isNotEmpty(tableField.value())) { return tableField.value(); } return StringTool.toUnderline(baseField.getName()); } }

最后我們就可以使用工具類來填充了 。

public List<UserMo> list (UserForm userForm) { QueryWrapper<UserMo> queryWrapper = new QueryWrapper<>(); QueryTool.paddingDefaultConditionQuery(UserMo.class, queryWrapper, userForm); return userMapper.selectList(queryWrapper);}

可以看到這樣大大減少了需要填充的字段。如果有特殊字段,也能通過注解方式,跳過特殊字段,再自行填充就好。

到此這篇關于關于mybatis plus 中的查詢優化的文章就介紹到這了,更多相關mybatis plus 查詢優化內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 合肥升降机-合肥升降货梯-安徽升降平台「厂家直销」-安徽鼎升自动化科技有限公司 | 大流量卧式砂磨机_强力分散机_双行星双动力混合机_同心双轴搅拌机-莱州市龙跃化工机械有限公司 | 微学堂-电动能源汽车评测_电动车性能分享网 | 莱州网络公司|莱州网站建设|莱州网站优化|莱州阿里巴巴-莱州唯佳网络科技有限公司 | 免联考国际MBA_在职MBA报考条件/科目/排名-MBA信息网 | 蓝鹏测控平台 - 智慧车间系统 - 车间生产数据采集与分析系统 | 立式_复合式_壁挂式智能化电伴热洗眼器-上海达傲洗眼器生产厂家 理化生实验室设备,吊装实验室设备,顶装实验室设备,实验室成套设备厂家,校园功能室设备,智慧书法教室方案 - 东莞市惠森教学设备有限公司 | 球形钽粉_球形钨粉_纳米粉末_难熔金属粉末-广东银纳官网 | 控显科技 - 工控一体机、工业显示器、工业平板电脑源头厂家 | 不锈钢管件(不锈钢弯头,不锈钢三通,不锈钢大小头),不锈钢法兰「厂家」-浙江志通管阀 | 生物颗粒燃烧机-生物质燃烧机-热风炉-生物颗粒蒸汽发生器-丽水市久凯能源设备有限公司 | 橡胶粉碎机_橡胶磨粉机_轮胎粉碎机_轮胎磨粉机-河南鼎聚重工机械制造有限公司 | 防腐木批发价格_深圳_惠州_东莞防腐木厂家_森源(深圳)防腐木有限公司 | 仓储货架_南京货架_钢制托盘_仓储笼_隔离网_环球零件盒_诺力液压车_货架-南京一品仓储设备制造公司 | 昆明化妆培训-纹绣美甲-美容美牙培训-昆明博澜培训学校 | 上海律师事务所_上海刑事律师免费咨询平台-煊宏律师事务所 | 铁盒_铁罐_马口铁盒_马口铁罐_铁盒生产厂家-广州博新制罐 | 电渗析,废酸回收,双极膜-山东天维膜技术有限公司 | 超声波清洗机-超声波清洗设备定制生产厂家 - 深圳市冠博科技实业有限公司 | 接地电阻测试仪[厂家直销]_电缆故障测试仪[精准定位]_耐压测试仪-武汉南电至诚电力设备 | 布袋式除尘器|木工除尘器|螺旋输送机|斗式提升机|刮板输送机|除尘器配件-泊头市德佳环保设备 | 圆形振动筛_圆筛_旋振筛_三次元振动筛-河南新乡德诚生产厂家 | 仓储笼_仓储货架_南京货架_仓储货架厂家_南京货架价格低-南京一品仓储设备制造公司 | 体检车_移动CT车_CT检查车_CT车_深圳市艾克瑞电气有限公司移动CT体检车厂家-深圳市艾克瑞电气有限公司 | 金属抛光机-磁悬浮抛光机-磁力研磨机-磁力清洗机 - 苏州冠古科技 | 浇注料-高铝砖耐火砖-郑州凯瑞得窑炉耐火材料有限公司 | 查分易-成绩发送平台官网 | 重庆网站建设,重庆网站设计,重庆网站制作,重庆seo,重庆做网站,重庆seo,重庆公众号运营,重庆小程序开发 | 细沙回收机-尾矿干排脱水筛设备-泥石分离机-建筑垃圾分拣机厂家-青州冠诚重工机械有限公司 | 皮带输送机-大倾角皮带输送机-皮带输送机厂家-河南坤威机械 | 动库网动库商城-体育用品专卖店:羽毛球,乒乓球拍,网球,户外装备,运动鞋,运动包,运动服饰专卖店-正品运动品网上商城动库商城网 - 动库商城 | 万濠影像仪(万濠投影仪)百科-苏州林泽仪器 | 无缝方管|无缝矩形管|无缝方矩管|无锡方管厂家 | 全国国际学校排名_国际学校招生入学及学费-学校大全网 | 无硅导热垫片-碳纤维导热垫片-导热相变材料厂家-东莞市盛元新材料科技有限公司 | 比士亚-专业恒温恒湿酒窖,酒柜,雪茄柜的设计定制 | 不锈钢法兰-碳钢法兰-法兰盘生产加工厂家-[鼎捷峰]-不锈钢法兰-碳钢法兰-法兰盘生产加工厂家-[鼎捷峰] | BHK汞灯-百科|上海熙浩实业有限公司| PCB厂|线路板厂|深圳线路板厂|软硬结合板厂|电路板生产厂家|线路板|深圳电路板厂家|铝基板厂家|深联电路-专业生产PCB研发制造 | 废气处理设备-工业除尘器-RTO-RCO-蓄热式焚烧炉厂家-江苏天达环保设备有限公司 | STRO|DTRO-STRO反渗透膜(科普)_碟滤 |