一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - MybatisPlus自定義Sql實現多表查詢的示例

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

2020-08-25 00:13牟野 Java教程

這篇文章主要介紹了MybatisPlus自定義Sql實現多表查詢的示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

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

分頁查詢VO對象

?
1
2
3
4
5
6
7
8
9
@Data
@AllArgsConstructor
@NoArgsConstructor
public class LayuiData {
  private Integer code=0;
  private Long count;
  private String msg="ok";
  private Object data;
}

Controller

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

?
1
2
3
4
5
6
7
8
9
10
@GetMapping("/getClientList")
@ResponseBody
public 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

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

ServiceImpl

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
@Override
public 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

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

XML內容

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<select id="findClientPage" 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 多表查詢內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/weixin_44906271/article/details/105770467

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 色一情一乱一伦 | 国产一级黄色录像 | 我的青梅竹马是消防员2季未增删免费 | 2021麻豆剧果冻传媒入口永久 | 亚洲swag精品自拍一区 | 艹的好爽 | 无码人妻丰满熟妇啪啪网不卡 | 国产偷窥 | 我和岳的性事小说 | 韩国美女豪爽一级毛片 | 国内小情侣一二三区在线视频 | 青草国产在线观看 | 亚洲精品www久久久久久 | sxx免费看视频在线播放 | 动漫美女隐私尿口图片 | 亚洲精品国产AV成人毛片 | 狠狠色狠狠色综合系列 | 色综合图区 | 天天做天天玩天天爽天天 | 女女宿舍互慰h文小说 | 无码区国产区在线播放 | 吃瓜视频在线观看 | 久久精品国产色蜜蜜麻豆国语版 | 欧亚精品一区二区三区 | 国产亚洲精品激情一区二区三区 | 亚洲国产第一区二区三区 | 欧美一区二区三区四区在线观看 | 日本xxwwwxxxx| 精品在线观看一区 | 国产福利自产拍在线观看 | 精品国产欧美精品v | 红杏网 | 91手机看片国产永久免费 | 亚洲丰满女人ass硕大 | 欧美一区二区三区不卡视频 | 日本漫画大全之工之口 | 成人精品在线 | 日韩网新片免费 | 91久久国产综合精品 | 国产福利视频一区二区微拍视频 | 国产一区二区在线免费观看 |