日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

關(guān)于mybatis plus 中的查詢優(yōu)化問題

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

傳統(tǒng)的mybatis plus 查詢寫法

對(duì)于常規(guī)的mybatis單表查詢,我們既可以采用LambdaQueryWrapper查詢,也可以使用QueryWrapper查詢。LambdaQueryWrapper具有防誤寫、規(guī)范代碼等好處,但是缺點(diǎn)是無法在復(fù)雜的多表查詢中使用。相比較來說,使用QueryWrapper編寫查詢更加靈活,可以適應(yīng)更復(fù)雜的查詢場(chǎng)景。我們首先看一個(gè)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);}

對(duì)于上面的查詢語句來說,可以很好的對(duì)前端傳值進(jìn)行處理,當(dāng)userForm中有前端傳值的話,就會(huì)往SQL語句中加一條where條件。但是這樣做的話會(huì)有一個(gè)相對(duì)來說比較復(fù)雜的點(diǎn),那就是當(dāng)UserForm中的字段過于多的時(shí)候,我們也許得寫十幾行的這種重復(fù)判斷的語句。

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

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

關(guān)于mybatis plus 中的查詢優(yōu)化問題

可以看出來這幾個(gè)方法都是傳的同樣的三個(gè)參數(shù)。我想對(duì)于這些簡(jiǎn)單的通用的查詢條件,也許可以有一個(gè)通用的方法來填充。我首先設(shè)置了一個(gè)枚舉類,將這些查詢條件列出來,并在構(gòu)造方法中,將對(duì)應(yīng)的方法以反射的方式取到。

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

再者,我想通過注解的方式來規(guī)定需要以什么方法填充,默認(rèn)為EQ,對(duì)此寫了一個(gè)QueryCondition注解。

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

然后就可以這樣構(gòu)造UserForm

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

我們需要一個(gè)工具類填充查詢條件,這里我們新增了一個(gè)參數(shù) mo對(duì)象,這是因?yàn)槲覀兊闹鞑樵儗?duì)象是Mo對(duì)象,Mo對(duì)象存儲(chǔ)了相關(guān)表格名稱、表格字段名信息。

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

public class QueryTool { /** * 填充默認(rèn)查詢 * @param baseClazz mo對(duì)象class * @param queryWrapper 查詢條件 * @param form 請(qǐng)求對(duì)象 */ 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('填充默認(rèn)的SQL條件出錯(cuò)', e); } } /** * 填充默認(rèn)排序 * * @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);}

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

到此這篇關(guān)于關(guān)于mybatis plus 中的查詢優(yōu)化的文章就介紹到這了,更多相關(guān)mybatis plus 查詢優(yōu)化內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Mybatis 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
福利一区二区三区视频在线观看| 国产99精品| 少妇精品久久久一区二区| 国精品产品一区| 日本亚洲视频在线| 99香蕉国产精品偷在线观看 | 91精品国产自产在线观看永久∴| 亚洲欧洲一区二区天堂久久| 在线精品亚洲欧美日韩国产| 麻豆精品av| 国产一区二区三区不卡av| 亚洲乱码一区| 亚洲精品欧美| 日韩中文字幕一区二区三区| 亚洲在线成人| 国产免费av一区二区三区| 美女精品视频在线| 欧美搞黄网站| 亚洲欧洲av| a天堂资源在线| 日韩一级不卡| 欧美激情日韩| 久久网站免费观看| 午夜在线精品| 视频一区国产视频| 国产精品福利在线观看播放| 亚洲调教视频在线观看| 欧美日韩国产高清| 丝袜诱惑制服诱惑色一区在线观看 | 日韩欧美三级| 日韩成人免费| 久久国产精品亚洲77777| 亚洲另类黄色| 国产精品一卡| 日韩三区免费| 蜜臀av性久久久久蜜臀aⅴ四虎| 午夜亚洲精品| 精品中文在线| 热久久国产精品| 三级欧美在线一区| 国产欧美啪啪| 人人爽香蕉精品| 美女网站一区| 中文字幕高清在线播放| 日韩精品a在线观看91| 欧美日韩色图| 你懂的网址国产 欧美| 中文字幕一区日韩精品| 99成人超碰| 精品网站999| 久久99久久久精品欧美| 在线 亚洲欧美在线综合一区| 天堂av在线| 美女久久精品| 精品网站aaa| 国产精品亚洲欧美一级在线| 日韩精品影视| 91p九色成人| 日韩黄色大片网站| 91精品麻豆| 综合国产精品| 尤物网精品视频| 色乱码一区二区三区网站| 国产激情综合| 久久这里只有精品一区二区| 亚洲精品日韩久久| 成人三级高清视频在线看| 欧美日韩黄网站| 在线精品视频一区| 亚洲人成毛片在线播放女女| 亚洲精品看片| 免费看一区二区三区| 国产精品115| 国产精品一区二区精品| 亚州av一区| 啪啪亚洲精品| 日本成人手机在线| 麻豆一区二区三| 国产aa精品| 99精品在线| 亚洲一级二级| 久久久久国产精品一区二区| 精品国产中文字幕第一页| 麻豆视频一区二区| 国产一区亚洲| 久久精品国产久精国产| 欧美日韩三区| 国产一区精品福利| 深夜福利一区| 欧美国产91| 国产精品tv| 婷婷亚洲五月| 欧美韩日一区| 久久99性xxx老妇胖精品| 欧美+日本+国产+在线a∨观看| 五月天久久777| 日韩高清欧美| 麻豆国产91在线播放| 亚洲最新av| 狠狠久久伊人中文字幕| 91精品观看| 久久麻豆视频| 日韩精品中文字幕一区二区| 亚洲一区欧美激情| 婷婷丁香综合| 欧美日韩亚洲在线观看| 加勒比视频一区| 在线日韩av| 免费观看亚洲天堂| 日产精品一区二区| 精品欧美久久| 视频福利一区| 日韩国产欧美在线视频| 久久中文字幕二区| 久久不卡日韩美女| 亚洲经典在线| аⅴ资源天堂资源库在线| 日韩精品中文字幕吗一区二区 | 麻豆国产精品| 中文字幕av一区二区三区四区| 国产精品字幕| 丁香婷婷久久| 国产精品夜夜夜| 久久国产99| 影音国产精品| 精品一区二区三区四区五区| 99热免费精品| 成人久久一区| а√天堂8资源在线| 国产精品视频一区视频二区| 亚洲v天堂v手机在线| 亚洲最新av| 欧美大黑bbbbbbbbb在线| 国产v日韩v欧美v| 韩国女主播一区二区三区| 国产精品一区二区美女视频免费看| 亚欧成人精品| 日韩1区2区3区| 日本午夜精品视频在线观看| 日韩一区二区三区在线看| 国产中文在线播放| 久久久精品久久久久久96| 国产成人精品亚洲日本在线观看| 波多野结衣久久精品| 韩国精品主播一区二区在线观看 | 亚洲天堂av资源在线观看| 九九在线精品| 中文日韩欧美| 蜜桃视频在线网站| 日本精品不卡| 国产视频亚洲| 综合精品一区| 久久国产麻豆精品| 国产69精品久久| 欧洲激情综合| 日本成人在线一区| 精品久久美女| 999久久久91| 女同性一区二区三区人了人一| 亚洲区国产区| 国模大尺度视频一区二区| 欧美成人午夜| 国产精品网在线观看| av在线最新| 亚洲天堂日韩在线| 日韩欧美精品一区| 深夜福利亚洲| 亚洲1234区| 欧美一区二区三区免费看| 国产成人调教视频在线观看| 青青青国产精品| 欧美精品一线| 午夜在线视频一区二区区别| 日韩av一二三| 精品免费视频| 亚洲色图综合| 日韩高清中文字幕一区二区| 丝袜国产日韩另类美女| 丝袜美腿亚洲一区| 欧美激情一区| 免费日韩视频| 精品国产中文字幕第一页| 亚洲永久字幕| 神马久久午夜| 红杏一区二区三区| 日韩精品一区二区三区av | 国产精品丝袜xxxxxxx| 国产91在线精品| 欧美亚洲国产一区| 久久99国产精品视频| 中文一区一区三区高中清不卡免费| 国产不卡人人| 天堂8中文在线最新版在线| 国产亚洲精品美女久久| 久久亚洲欧美| 欧美日韩国产免费观看| 国产成人精品一区二区免费看京| 午夜欧美理论片| 日韩一区网站| 欧美激情视频一区二区三区在线播放|