首页
/
每日頭條
/
科技
/
mybatis雙表查詢
mybatis雙表查詢
更新时间:2026-01-28 16:33:00

mybatis雙表查詢? Mybatis-Plus缺省是不帶多表關聯功能,多表關聯需要作用mapper.xml寫SQL語句,或都在domain的mapper對象下使用@Select注解寫SQL語句,用後種方法根據自己的需要,花了一天時間學習研究,做了自己的第一個帶查詢條件的多表關聯SQL,特此記錄:,我來為大家科普一下關于mybatis雙表查詢?以下内容希望對你有幫助!

mybatis雙表查詢(Mybatis-plus帶查詢參數的多表關聯)1

mybatis雙表查詢

Mybatis-Plus缺省是不帶多表關聯功能,多表關聯需要作用mapper.xml寫SQL語句,或都在domain的mapper對象下使用@Select注解寫SQL語句,用後種方法根據自己的需要,花了一天時間學習研究,做了自己的第一個帶查詢條件的多表關聯SQL,特此記錄:

一、功能說明

當前有兩個表,第一表是景區基本信息,第二個表是景區的文檔記錄表,第二個表隻記錄了景區ID代碼,查管理第二個表時,需要使用第一個表的信息如景區名稱,景區所在行政區劃的編碼,并要根據表一的景區名稱,區劃編碼,表二的文件代碼、文件主題,景區編碼進行查詢。

二、實現方法

1、編寫VO對象

增加了個VO對象,擴展表二對象,同時需要将使用表一的字段添加上,形成一個完整的View對象,且續參數傳遞,查詢操作對使用這個VO對象。

@Data public class MapScenicFileVO extends MapScenicFile { private String scenicName; private String scenicAdcode; }

2、mapper對象擴展函數

添加表聯合功能,使用@select注解方式添加,這個表是采用join進行聯合,以便後面傳遞wrapper查詢條件組合。使用where子句聯合,後面傳遞參數時又會産生where子句,導緻查詢錯誤。

注意${ew.customSqlSegment}是傳遞自定義條件到SQL工廠。

/** * 景區文件聯合景區名稱查詢 * * @param wrapper 翻頁對象,可以作為 xml 參數直接使用,傳遞參數 Page 即自動分頁 * @return 列表 */ @Select("SELECT map_scenic_file.*,map_scenic.`name` as `scenic_name`,map_scenic.`adcode` as `scenic_adcode` FROM map_scenic_file left join map_scenic on map_scenic_file.scenic_id=map_scenic.id ${ew.customSqlSegment}") List<MapScenicFileVO> selectScenicFile(@Param(Constants.WRAPPER) Wrapper wrapper);

3、構建執行方法

在服務層執行函數中,根據需要構建組合查詢的QuerWrapper,注意Long和String空判斷方式不一樣。

public List<MapScenicFileVO> selectScenicFileList(MapScenicFileVO scenicFile) { QueryWrapper<MapScenicFileVO> scenicFileQueryWrapper = new QueryWrapper<>(); //構造查詢條,按文件ID,景區ID,景區名稱,文件主題構建查詢條件 if (scenicFile.getId() !=null ) { scenicFileQueryWrapper.eq("map_scenic_file.id",scenicFile.getId()); } if (scenicFile.getScenicId() !=null ) { scenicFileQueryWrapper.eq("map_scenic_file.scenic_id",scenicFile.getScenicId()); } if (StringUtils.isNotEmpty(scenicFile.getScenicName())) { scenicFileQueryWrapper.like("map_scenic.name",scenicFile.getScenicName()); } if (StringUtils.isNotEmpty(scenicFile.getsubject())) { scenicFileQueryWrapper.like("map_scenic_file.subject",scenicFile.getSubject()); } return baseMapper.selectScenicFile(scenicFileQueryWrapper); }

4、對應的Service接口,Controller統一改為使用VO對象即可,分頁方法我是采用pagahelper,下次再研究改為mybatis-plus的分而方法

三、前端

前端調用沒什麼區别一樣,注意一下VO對象的名稱,兩個表聯合有些名稱已用AS改過了,

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
30道五年級解方程應用題
30道五年級解方程應用題
五年級數學:100道解方程應用題(含解答)打印練習,必過98!由于篇幅原因,沒有分享完,按下方方式可以免費獲取完整資料。同時可以領取快速提升10倍學習效率的方法,隻需3天,即可輕松掌握!真正實現輕松快樂學習!,
2026-01-28
使命召喚戰區哪個服務器人多
使命召喚戰區哪個服務器人多
它有機會發展成品類中的另一極,還是會像《Apex英雄》那樣高開低走?文/安德魯戰網崩了?這周早些時候,很多玩家都發現自己的戰網登不上去了。《使命召喚:戰區》(CallofDuty:WarZone)上線後的火爆,讓動視暴雪和自家用戶都措手不及...
2026-01-28
西安一級注冊建築師考試報名
西安一級注冊建築師考試報名
西安一級注冊建築師考試報名?近日,鷗瑪軟件圓滿完成2022年度全國一級注冊建築師資格考試作圖題評卷服務項目,首次實現了答卷數字化與網上評卷新模式,終結了該項考試長達二十餘年的人工翻卷評閱模式,極大地提高了工作效率、降低了勞動強度、簡化了評卷...
2026-01-28
哪款性價比高的筆記本值得擁有
哪款性價比高的筆記本值得擁有
如今中高端筆記本産品并不是占滿整個電腦市場的主體,4000至7000的電腦往往成為人們的最佳選擇,對于學生來說,買4000元的電腦不僅價位不高,而且也滿足了學生的經濟實力,今天筆者就和大家聊一聊有哪些4千元的電腦值得學生購買!01榮耀Mag...
2026-01-28
水印如何去除幹淨
水印如何去除幹淨
随着短視頻行業越來越火爆,相關從業者也越來越多。對于新手小白來說,前期可能主要是通過借用其他視頻素材進行二次創作。可是從網上下載的視頻素材,基本都會帶着水印,确實會讓人很苦惱。那肯定是要将視頻上的水印去除掉才能使用了。其實很多視頻去水印後都...
2026-01-28
Copyright 2023-2026 - www.tftnews.com All Rights Reserved