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

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

MybatisPlus自定義Sql實現多表查詢的示例

瀏覽:202日期:2023-10-23 10:26:47

前言

前段時間看同事的代碼,發現他用Layui+MybatisPlus做分頁查詢做得很規整,認真看了下代碼發現這種方式不僅適用于與Layui做分頁查詢,在任何時候需要多表聯查的時候都可以用到。 以下以Layui分頁查詢作為參考,在實際應用中可以靈活使用。

分頁查詢VO對象

@Data@AllArgsConstructor@NoArgsConstructorpublic class LayuiData { private Integer code=0; private Long count; private String msg='ok'; private Object data;}

Controller

這里的“keyWord”和“registerTime”是后臺頁面可以查詢的字段,也就是普通的參數,可以靈活變通。

@GetMapping('/getClientList')@ResponseBodypublic LayUIResult getAll( @RequestParam(name = 'page', required = true, defaultValue = '1') int num, @RequestParam(name = 'limit', required = true, defaultValue = '10') int size, String keyWord, String registerTime){ IPage<Map<String, Object>> listPage = clientService.findClientPage(num, size, keyWord,registerTime); //返回總數和數據 return new LayuiData (listPage.getTotal(),listPage.getRecords());}

Service

IPage<Map<String, Object>> findClientPage(Integer num, Integer size, String keyWord, String registerTime);

ServiceImpl

這里的QueryWrapper內的實例是<Map<String, Object>,不是平常的實體類,返回的也是Map。

@Overridepublic IPage<Map<String, Object>> findClientPage(Integer num, Integer size, String keyWord, String registerTime) { //創建QueryWrapper搜索對象,判斷參數不為空則傳入參數 QueryWrapper<Map<String, Object>> wrapper = new QueryWrapper<>(); if (StringUtils.isNotEmpty(keyWord)) { wrapper.like('c.real_name', keyWord).or().like('c.phone', keyWord); } if (StringUtils.isNotEmpty(registerTime)) { String stime = registerTime.substring(0, 20); String etime = registerTime.substring(22, 41); wrapper.ge('c.register_time', stime).le('c.register_time', etime); } //創建分頁對象 Page<Map<String, Object>> page = new Page<>(num, size); return clientMapper.findClientPage(page, wrapper);}

Mapper

格式要求,QueryWrapper前面加上@param,括號里的Constants.WRAPPER內容就是'ew',對應xml文件里的ew

IPage<Map<String, Object>> findClientPage(Page<Map<String, Object>> page,@Param(Constants.WRAPPER) QueryWrapper<Map<String, Object>> wrapper);

XML內容

重點在于我們用${ew.customSqlSegment}放在sql語句里,它可以直接把我們的wrapper里的查詢數據等同于where查詢添加進去

<select resultType='java.util.Map'> SELECT c.id,c.real_name,c.phone,c.`status`, //實現將時間轉換成固定格式 DATE_FORMAT(c.register_time,’%Y-%m-%d %H:%i:%s’) registerTime, SUM(re.money) rechargeMoney, SUM(wi.withdrawal_money) withdrawalMoney,SUM(buy_money) orderMoney, wa.balance FROM client c LEFT JOIN recharge re ON c.id=re.client_id LEFT JOIN withdrawal wi ON c.id=wi.client_id LEFT JOIN wallet wa ON c.id=wa.client_id LEFT JOIN order_position ord on c.id=ord.client_id //重點是這里會插入wrapper的搜索語句 ${ew.customSqlSegment} GROUP BY c.id</select>

總結

這種方式相當于在業務層已經做好了參數判斷,不用再在xml文件內用“if”標簽判斷了。 除了在與Layui做分頁查詢外,在別的需要參數請求的地方也都可以變通的用這種方法,在使用MybatisPlus時使用這種方式可以使代碼更簡潔,更清晰。 除此之外,在需要多表聯查的時候,這種方式是非常適用的。

MybatiPlus文檔

官方文檔里面也做介紹,版本需要大于3.0.7官方鏈接:使用 Wrapper 自定義SQL

MybatisPlus自定義Sql實現多表查詢的示例

到此這篇關于MybatisPlus自定義Sql實現多表查詢的示例的文章就介紹到這了,更多相關MybatisPlus 多表查詢內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产调教精品| 在线综合亚洲| 亚洲精品成人一区| 蜜桃视频一区二区| 午夜一区在线| 视频一区国产视频| 蜜臀久久99精品久久一区二区| sm久久捆绑调教精品一区| 精品欠久久久中文字幕加勒比| 欧美色综合网| 国产精品黄色| 精品久久久久久久| 久久毛片亚洲| 欧美日韩视频网站| 欧美色图国产精品| 夜夜嗨av一区二区三区网站四季av| 悠悠资源网久久精品| 美女精品在线| 日韩一区二区三免费高清在线观看| 日韩精品导航| 久久中文字幕一区二区| 久久97视频| 在线手机中文字幕| 天堂网在线观看国产精品| 蜜臀久久99精品久久久画质超高清 | 日韩综合小视频| 日本va欧美va瓶| 日韩中文av| 国产欧美日韩在线观看视频 | 亚洲精品三级| 日韩精品91亚洲二区在线观看| 亚洲免费毛片| 麻豆视频观看网址久久| 欧美韩一区二区| 日韩av福利| 香蕉成人久久| 日韩高清不卡在线| 国产一区二区三区91| 日韩成人亚洲| 亚洲欧美视频一区二区三区| 国产精品一卡| 欧美aa一级| 石原莉奈在线亚洲二区| 视频一区在线播放| 精品一区二区三区四区五区| 青青久久av| 综合色就爱涩涩涩综合婷婷| 国产欧美激情| 天堂√8在线中文| 久久aⅴ国产紧身牛仔裤| 国产一精品一av一免费爽爽| 三上悠亚国产精品一区二区三区| 免费国产自线拍一欧美视频| 欧美亚洲一级| 国产不卡精品在线| 红桃视频国产一区| 国产乱码精品一区二区三区亚洲人| 日本精品黄色| 欧美 日韩 国产一区二区在线视频 | 精品美女在线视频| 国产视频欧美| 欧美在线黄色| 手机在线电影一区| 综合激情网站| 一区二区三区四区日本视频| 蜜桃视频一区二区三区在线观看| 精品国产亚洲日本| 蜜臀av国产精品久久久久| 97精品一区二区| 四虎精品永久免费| 裤袜国产欧美精品一区| 中文字幕日韩亚洲| 天堂中文在线播放| 无码日韩精品一区二区免费| 国产一区二区三区久久| 久久国产精品久久久久久电车| 久久伊人国产| 日韩有码av| 精品美女在线视频| 涩涩涩久久久成人精品| 999视频精品| 麻豆精品在线观看| 蜜桃视频一区二区| 亚洲高清成人| 日韩高清电影一区| 电影天堂国产精品| 久久国产尿小便嘘嘘| 丝袜美腿亚洲色图| 久久久久久黄| 国产精品亲子伦av一区二区三区| 亚洲激情黄色| 一本大道色婷婷在线| 久久亚洲精品中文字幕| 午夜久久av | 国产精品一区亚洲| 激情欧美丁香| 岛国精品一区| 红桃视频欧美| 91欧美在线| 久久国产日韩欧美精品| 免费欧美在线视频| 伊人成人网在线看| 91精品国产乱码久久久久久久| 久久免费精品| 国产精品17p| 欧美视频一区| 日韩av不卡一区二区| 日韩中文字幕1| 亚洲激精日韩激精欧美精品| 人人精品亚洲| 久久久精品五月天| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 日本免费久久| 精品中文字幕一区二区三区| 日韩区一区二| 亚洲毛片一区| 性一交一乱一区二区洋洋av| 欧美日韩国产高清| 久久一级电影| 久久激情一区| 久久久精品日韩| 久久久久.com| 美女网站一区| 激情五月色综合国产精品| 99精品电影| 久久国产主播| 亚洲午夜av| 国产一区日韩欧美| 激情综合网站| 欧美日韩免费观看一区=区三区 | 高清在线一区| 精品国产亚洲日本| 精品成人18| 高清一区二区| 亚洲精品永久免费视频| 成人午夜网址| 激情中国色综合| 国产一区二区三区免费在线 | 欧美极品中文字幕| 欧美一区激情| 国产精品xxx| 国内揄拍国内精品久久| 麻豆91在线播放| 成人免费一区| 99久久99久久精品国产片果冰| 亚洲高清av| 在线亚洲自拍| 一区二区三区午夜视频| 一本综合精品| 国产精品视频3p| 91综合网人人| 激情欧美一区二区三区| 日韩欧美精品| 2023国产精品久久久精品双| 视频在线观看91| 日本伊人久久| 国产一区丝袜| 久久久噜噜噜| 在线看片不卡| 日韩中文字幕无砖| 久久精品免费看| 亚洲免费福利| 午夜在线视频一区二区区别| 日韩在线观看一区二区三区| 国产精品观看| 久久久久国产| 丝瓜av网站精品一区二区| 国产精品亚洲人成在99www | 免费的成人av| 爽好多水快深点欧美视频| 国产麻豆一区二区三区| 国产精品magnet| 日韩国产欧美一区二区| 9色精品在线| 免费一级欧美片在线观看网站 | 午夜av一区| 国产亚洲精aa在线看| 亚洲涩涩在线| 视频精品一区二区| 精品国产麻豆| 亚洲一区黄色| 免费亚洲婷婷| 美女久久一区| 国产精品视频3p| 五月天久久久| 久久精品福利| 在线一区免费观看| 国产精品天天看天天狠| 99精品在线| 国产精品极品在线观看| 在线亚洲国产精品网站| 麻豆一区二区99久久久久| 成人av二区| 日本欧美一区二区在线观看| 欧美成人a交片免费看| 日本中文字幕视频一区| 亚洲高清毛片| 麻豆精品久久| 一区二区电影在线观看| 亚洲免费福利|