Mybatis-Plus缺省是不带多表关联功能,多表关联需要作用mapper.xml写SQL语句,或都在domain的mapper对象下使用@Select注解写SQL语句,用后种方法根据自己的需要,花了一天时间学习研究,做了自己的第一个带查询条件的多表关联SQL,特此记录:,我来为大家科普一下关于mybatis双表查询?以下内容希望对你有帮助!

mybatis双表查询(Mybatis-plus带查询参数的多表关联)

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改过了,

,