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

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

基于Mybatis Plus實現(xiàn)多表分頁查詢的示例代碼

瀏覽:23日期:2023-10-20 18:41:50

注意:Mybatis Plus 3.0.7 版本才開始用【自定義sql】+【QueryWrapper】,低版本不能使用,還是老實寫SQL進行條件拼接

1、源碼分析

在Wrapper<T>接口中就有如下方法

/** * 獲取自定義SQL 簡化自定義XML復(fù)雜情況 * 使用方法:自定義sql + ${ew.customSqlSegment} * 1.邏輯刪除需要自己拼接條件 (之前自定義也同樣) * 2.不支持wrapper中附帶實體的情況 (wrapper自帶實體會更麻煩) * 3.用法 ${ew.customSqlSegment} (不需要where標(biāo)簽包裹,切記!) * 4.ew是wrapper定義別名,可自行替換 */public abstract String getCustomSqlSegment();

在AbstractWrapper抽象類中進行了實現(xiàn)

@Overridepublic String getCustomSqlSegment() { // MergeSegments 為 返回 合并 SQL 片段 MergeSegments expression = getExpression(); if (Objects.nonNull(expression)) { NormalSegmentList normal = expression.getNormal(); String sqlSegment = getSqlSegment(); if (StringUtils.isNotEmpty(sqlSegment)) { if (normal.isEmpty()) { return sqlSegment; } else { return concatWhere(sqlSegment); } } } return StringUtils.EMPTY;}/** * 拼接`WHERE`至SQL前 * * @param sql sql * @return 帶 where 的 sql */private String concatWhere(String sql) { return Constants.WHERE + ' ' + sql;}

2、案例講解

2.1、dao

說明:1、這里Dao層需要繼承BaseMapper,泛型指定為查詢實體;2、@Mapper,這個無過多說明;3、最重要的是方法形參@Param('ew') QueryWrapper<ReseEntity> queryWrapper,這里是使用mybatisplus的條件構(gòu)造器(超鏈接進官方文檔),【2.3、service】中有說明

@Mapperpublic interface ReseDao extends BaseMapper<ReseEntity> { /** * 分頁查詢 * @param page:mybatisPlus 原生分頁查詢,查詢SQL會自動拼接分頁 * @param queryWrapper:QueryWrapper條件,注意,這里需要使用 @Param('ew') 指定mybatis參數(shù) * @return */ IPage<ReseEntity> getReseList(IPage<T> page, @Param('ew') QueryWrapper<ReseEntity> queryWrapper);}

2.2、xml說明:1、查詢SQL寫完后,不用寫【W(wǎng)HERE】,在SQL后面加入【 ${ew.customSqlSegment}】,mybatisPlus會自動將查詢添加進行拼接

2、為什么是ew:mybatisPlus 之前有EntityWrapper,在后面版本將EntityWrapper分化為了多個Wrapper,例如查詢的時候,就是QueryWrapper,猜測可能之前通過ew引用地方太多,保留了使用ew

<select resultMap='reseMap'> SELECT r.rese_id, r.rese_no, w.WORK_Name FROM t_s_db_rese r left join t_s_db_work w on r.WORK_id = w.WORK_id ${ew.customSqlSegment}</select>

2.3、service

說明:1、getPage(params, null, false): 方法用來拼接mybatis plus 分頁組件(超鏈接進官方文檔)2、getWrapper(params):方法用來拼接 QueryWrapper 條件構(gòu)造器(超鏈接進官方文檔),

/** * 分頁查詢 * getPage(params, null, false): 方法用來拼接mybatis plus 分頁組件的那個類 * getWrapper(params):方法用來拼接 QueryWrapper 條件構(gòu)造器 */@Overridepublic PageData<ReseDTO> page(Map<String, Object> params) { IPage<ReseEntity> page = reseDao.getReseList( // 調(diào)用 分頁組件返回 IPage對象 getPage(params, null, false), // 調(diào)用 條件構(gòu)造器 返回 Wrapper getWrapper(params) ); return getPageData(page, ReseDTO.class);}/*** 查詢條件:調(diào)用構(gòu)造器* @param params 查詢條件,如果需要分頁,則這個里面有分頁參數(shù)* @return*/private QueryWrapper<ReseEntity> getWrapper(Map<String, Object> params) { QueryWrapper<CarBrandEntity> wrapper = new QueryWrapper<>(); /* eq 等于 = 參數(shù)說明: 參數(shù)1、params.get('xxx') != null :如果不為null,則將eq添加到wrapper中;為null不添加 參數(shù)2、w.WORK_Name,數(shù)據(jù)中的字段,多表查詢指定要指定字段的表前綴 參數(shù)3、params.get('xxx'),輸入的查詢添加 若下面eq( )方法成立,添加在wrapper中,則查詢SQL如下: SELECT r.rese_id, r.rese_no, w.WORK_Name FROM t_s_db_rese r left join t_s_db_work w on r.WORK_id = w.WORK_id where w.WORK_Name = '查詢條件' */ wrapper.eq(params.get('xxx') != null, 'w.WORK_Name', params.get('xxx')); return wrapper;} /*** * 分頁查詢 * @param params 查詢條件,主要是分頁的(頁碼、顯示內(nèi)容、排序規(guī)則) * @param defaultOrderField 默認排序規(guī)則 * @param isAsc 是否排序 * @return */public IPage getPage(Map<String, Object> params, String defaultOrderField, boolean isAsc) { long curPage = 1L; long limit = 20L; if (params.get(Constant.PAGE) != null) { curPage = Long.parseLong((String) params.get(Constant.PAGE)); } if (params.get(Constant.LIMIT) != null) { limit = Long.parseLong((String) params.get(Constant.LIMIT)); } Page page = new Page(curPage, limit); if (isAsc) { page.setAsc(new String[]{defaultOrderField}); } else { page.setDesc(new String[]{defaultOrderField}); } return page;}

到此這篇關(guān)于基于Mybatis Plus實現(xiàn)多表分頁查詢的示例代碼的文章就介紹到這了,更多相關(guān)Mybatis Plus多表分頁查詢內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Mybatis 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
黑森林国产精品av| 免费在线观看一区二区三区| 日韩一区二区三区高清在线观看| 国产一区日韩一区| 久久九九精品| 日韩天堂av| 91精品国产91久久久久久黑人| 美女视频黄久久| 精品国产免费人成网站| 亚洲成人国产| 亚洲综合不卡| 亚洲毛片视频| 国产毛片精品| 日韩av有码| 久久国产电影| 亚洲在线免费| 日本午夜免费一区二区| 久久av免费| 国产精品99一区二区三区| 亚洲欧洲美洲av| 免费观看久久久4p| 亚洲高清不卡| 美女毛片一区二区三区四区最新中文字幕亚洲 | 福利片在线一区二区| 国产精品伊人| 国产色噜噜噜91在线精品| 美女视频免费精品| 老司机精品视频网| 国产videos久久| 正在播放日韩精品| 日韩不卡免费高清视频| 欧美精品一区二区三区精品| 一区在线观看| 在线视频观看日韩| 久久要要av| 日韩亚洲在线| 日本欧美在线看| 综合激情网...| 日韩精品亚洲专区| 久久激五月天综合精品| 欧美视频久久| 美女久久久久久| 黑人精品一区| 伊人精品一区| 免费成人性网站| 国产日产一区| 成人午夜国产| 亚洲成人精选| 在线综合视频| 日韩在线麻豆| 国产精品白浆| 国产精品99一区二区三区| 亚洲伦乱视频| 日韩精品一区第一页| 国产精品videosex极品| 久久影院午夜精品| 国产亚洲亚洲| 老色鬼精品视频在线观看播放| 日韩综合精品| 亚洲激情偷拍| 日本伊人午夜精品| 麻豆国产91在线播放| 欧美一区二区三区高清视频| 午夜一区在线| 日韩成人精品一区二区三区| 久久成人福利| 99国产精品免费视频观看| 亚洲一区中文| 国产精品大片| 色网在线免费观看| 在线看片日韩| 免费亚洲一区| 亚洲成人三区| 日本欧美一区| 在线观看精品| 亚洲开心激情| 福利一区和二区| 亚洲综合日韩| 国产精品最新| 久久中文亚洲字幕| 欧美精品99| 欧美在线亚洲| 乱一区二区av| 国产精品试看| 精品国产中文字幕第一页| 99香蕉国产精品偷在线观看 | 国产精品成久久久久| 欧美日韩精品免费观看视完整 | 久久字幕精品一区| 99国产成+人+综合+亚洲欧美| 国产精品巨作av| 激情综合网站| 深夜福利一区| 另类专区亚洲| 国产精品magnet| 午夜亚洲精品| 91av亚洲| 国产精品成人**免费视频| 精品一区在线| 免费一级欧美片在线观看网站| 欧美精品一区二区三区精品| 日韩久久一区| 欧美日韩精品在线一区| 国产精品v亚洲精品v日韩精品| 91久久视频| 在线一区av| 国产精品一区免费在线| 国产99久久| 另类综合日韩欧美亚洲| 亚洲丝袜美腿一区| 亚洲高清av| 国产精品亚洲四区在线观看| 亚洲精品动态| 在线一区免费| 日韩国产一区二区三区| 国产精品亚洲综合在线观看| 亚洲欧美久久| 日韩成人亚洲| 精品三级在线| 日韩精品a在线观看91| 日韩视频一区| 国产一区日韩欧美| 国产精品yjizz视频网| 国产乱人伦丫前精品视频| 噜噜噜久久亚洲精品国产品小说| 久久久一二三| 日韩黄色大片网站| 精品99在线| 国产日韩一区二区三区在线播放| 视频一区二区三区入口| 国产91精品对白在线播放| 欧美黄色精品| 国产欧美69| 亚洲人成亚洲精品| 老牛影视一区二区三区| 欧美日韩一二三四| 亚洲一区资源| av在线资源| 岛国av免费在线观看| 欧美国产精品| 国产精品久久久网站| 日本不卡高清| 亚洲精品伦理| 日本成人在线视频网站| 日本亚洲最大的色成网站www| 亚洲综合色婷婷在线观看| 亚洲小说欧美另类婷婷| 亚洲精品国产嫩草在线观看 | 色综合视频一区二区三区日韩 | 国产一卡不卡| 日韩av不卡在线观看| 日本不卡中文字幕| 欧美亚洲综合视频| 欧美日韩xxxx| 日韩精品午夜视频| 日韩avvvv在线播放| 日韩av一区二区在线影视| 日本免费在线视频不卡一不卡二| 日韩精品欧美精品| 国产欧美日韩一区二区三区在线| 国产精品主播在线观看| 91九色综合| 中文字幕av亚洲精品一部二部 | 午夜久久福利| 99视频一区| 狠狠爱www人成狠狠爱综合网| 精品一区欧美| 欧美日韩激情| 美女91精品| 日本不卡视频一二三区| 久久国内精品视频| 国产精品久久国产愉拍| 精品一区二区三区中文字幕在线| 国产66精品| 99成人超碰| 久久国产成人午夜av影院宅| 快播电影网址老女人久久| 亚洲欧洲日本mm| 亚洲18在线| 老鸭窝一区二区久久精品| 欧美国产一级| 免费国产自久久久久三四区久久| 亚洲激情不卡| 日韩国产欧美在线播放| 美女视频黄免费的久久| 亚洲播播91| 亚洲综合电影一区二区三区| 亚洲精品国模| 免费在线观看日韩欧美| 日韩不卡免费高清视频| 尤物在线精品| 日韩不卡免费高清视频| 亚洲综合精品| 日韩精品一页| 麻豆精品在线视频| 色婷婷久久久| 亚洲三级精品| 国产欧美日韩一区二区三区四区| 精品久久久久中文字幕小说| 久久香蕉国产|