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

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

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

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

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

對(duì)于常規(guī)的mybatis單表查詢,我們既可以采用LambdaQueryWrapper查詢,也可以使用QueryWrapper查詢。LambdaQueryWrapper具有防誤寫(xiě)、規(guī)范代碼等好處,但是缺點(diǎn)是無(wú)法在復(fù)雜的多表查詢中使用。相比較來(lái)說(shuō),使用QueryWrapper編寫(xiě)查詢更加靈活,可以適應(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ì)于上面的查詢語(yǔ)句來(lái)說(shuō),可以很好的對(duì)前端傳值進(jìn)行處理,當(dāng)userForm中有前端傳值的話,就會(huì)往SQL語(yǔ)句中加一條where條件。但是這樣做的話會(huì)有一個(gè)相對(duì)來(lái)說(shuō)比較復(fù)雜的點(diǎn),那就是當(dāng)UserForm中的字段過(guò)于多的時(shí)候,我們也許得寫(xiě)十幾行的這種重復(fù)判斷的語(yǔ)句。

通過(guò)自定義注解來(lái)解決通用查詢條件過(guò)多問(wèn)題

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

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

可以看出來(lái)這幾個(gè)方法都是傳的同樣的三個(gè)參數(shù)。我想對(duì)于這些簡(jiǎn)單的通用的查詢條件,也許可以有一個(gè)通用的方法來(lái)填充。我首先設(shè)置了一個(gè)枚舉類,將這些查詢條件列出來(lái),并在構(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ò)注解的方式來(lái)規(guī)定需要以什么方法填充,默認(rèn)為EQ,對(duì)此寫(xiě)了一個(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()); } }

最后我們就可以使用工具類來(lái)填充了 。

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

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

到此這篇關(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)!

相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日日摸夜夜添夜夜添国产精品| 在线一区欧美| 五月天久久久| 成人影视亚洲图片在线| 美日韩一区二区三区| 国产精品视频一区二区三区| 国产精品草草| 国产成人久久精品一区二区三区| 精品国产黄a∨片高清在线| 超级白嫩亚洲国产第一| 夜鲁夜鲁夜鲁视频在线播放| 久久国产欧美| 亚洲综合日本| 欧美日韩中出| 中文字幕在线高清| 欧美日韩国产精品一区二区亚洲| 六月丁香综合| 国产精品一国产精品k频道56| 欧美在线91| 久久av免费| 国产传媒在线| 欧美成人综合| 日本精品久久| 黄色网一区二区| 国产精品日本欧美一区二区三区| 综合一区二区三区| 国产精品99久久免费| 日韩黄色大片网站| 最新日韩av| 亚洲精品中文字幕99999| 美女国产精品久久久| 久久久久中文| 日本不卡一区二区| 成人午夜亚洲| 亚洲在线成人| 精品一区二区三区中文字幕 | 蜜臀精品久久久久久蜜臀| 日韩一区中文| 国产v日韩v欧美v| 亚洲一区二区免费看| 欧美黄页在线免费观看 | 成人va天堂| 四虎在线精品| 久久精品123| 视频一区视频二区中文字幕| 国产日韩中文在线中文字幕| 久久亚洲成人| 欧美国产中文高清| 一本一本久久| 久久精品九色| 蜜桃视频一区二区三区在线观看| 精品视频在线观看网站| 蜜乳av另类精品一区二区| 国产精品男女| 日韩精品一二三区| 色偷偷色偷偷色偷偷在线视频| 亚洲精品一级| 妖精视频成人观看www| 91综合视频| 日韩国产在线观看一区| 亚洲国产一区二区在线观看| 国产精品二区不卡| 国产精品嫩草影院在线看| 国产精品日韩| 亚洲高清激情| 久久毛片亚洲| 国产精品亚洲欧美| 乱人伦精品视频在线观看| 日韩欧美另类一区二区| 久久99青青| 日韩动漫一区| 国产精品嫩草99av在线| 亚洲国产专区校园欧美| 日韩成人精品一区| 日韩欧美另类中文字幕| 国产麻豆综合| 99视频精品全国免费| 高清不卡一区| 国产黄色精品| 国产欧美日韩一级| 91欧美极品| 一级成人国产| 亚洲欧美久久| 夜夜嗨一区二区三区| 欧美99久久| 精品1区2区3区4区| 欧美日韩国产综合网| 欧美 日韩 国产一区二区在线视频 | 国产欧美激情| 欧美日韩1区2区3区| 亚洲欧美在线专区| 亚洲精品无吗| 日本在线不卡视频| 日韩精品久久久久久| 日本色综合中文字幕| 亚洲精品看片| 日韩一区二区三区在线看| 亚洲区欧美区| 97成人超碰| 欧美a一区二区| 国产一区二区三区不卡av| www.com.cn成人| 91综合网人人| 成人亚洲欧美| 欧美日韩免费看片| 国产99亚洲| 国产亚洲在线观看| 亚洲一区二区免费在线观看| 亚洲精品日本| 国产精品亚洲综合色区韩国| 国产精品地址| 成人午夜网址| 99久久99视频只有精品| 亚洲一区网站| 91亚洲精品在看在线观看高清| 国产伦精品一区二区三区千人斩 | 日韩av二区在线播放| 国产毛片精品久久| 国产精品99一区二区三| 亚洲手机在线| 亚洲一区二区日韩| 欧美亚洲一级| 成午夜精品一区二区三区软件| 91精品啪在线观看国产18| 日韩亚洲国产欧美| 日韩在线观看中文字幕| 国产精品1区| 高清久久精品| 久久精品影视| 亚洲免费一区二区| 国产精品久久久久久妇女| 97人人精品| 亚洲自拍另类| 欧美国产先锋| 亚洲国产专区校园欧美| 亚洲+小说+欧美+激情+另类| 国产一区二区三区探花| 最新国产拍偷乱拍精品| 欧美日韩一区二区三区四区在线观看| 国产伊人久久| 美女精品一区| 国产suv精品一区二区四区视频| 欧美aa国产视频| 日韩不卡在线观看日韩不卡视频 | 国产欧美精品久久| 久久精品导航| 日韩av一区二区三区四区| 日韩欧美综合| 亚洲aa在线| av高清不卡| 日韩高清在线不卡| 色偷偷色偷偷色偷偷在线视频| 蜜臀va亚洲va欧美va天堂| 黄色网一区二区| 综合激情一区| 国产高潮在线| 三级在线观看一区二区| 欧美激情aⅴ一区二区三区| 91久久久精品国产| 麻豆中文一区二区| 视频一区视频二区中文字幕| 成人国产精品一区二区免费麻豆| 蜜桃视频一区二区三区在线观看| 91亚洲国产成人久久精品| 亚洲精品动态| 久久婷婷av| 国产黄色精品| 综合欧美亚洲| 国产99久久| 国产a亚洲精品| 国产日产精品_国产精品毛片| 久久久久久久久丰满| 国产精品视频一区二区三区四蜜臂 | 精品久久不卡| 日韩二区在线观看| 久久aⅴ国产紧身牛仔裤| 动漫av一区| 青青草伊人久久| 国产字幕视频一区二区| 美女久久久精品| 日韩精品91亚洲二区在线观看| 激情婷婷综合| 国产不卡精品| 国产精品v亚洲精品v日韩精品| 亚洲影视一区| 亚洲欧美日本日韩| 欧美日一区二区| 正在播放日韩精品| 给我免费播放日韩视频| 国产高清视频一区二区| 日韩在线观看一区二区三区| 国产亚洲在线| 欧美午夜精品一区二区三区电影| 精品一区二区三区的国产在线观看 | 国产精品成人自拍| 欧美日韩一视频区二区| 日韩 欧美一区二区三区| 99国产精品久久久久久久成人热 | 欧美精品观看| 国产日韩欧美在线播放不卡|