MyBatis-Plus 如何实现连表查询的示例代码

 更新时间:2020年08月24日 09:57:24   作者:liujianko  
这篇文章主要介绍了MyBatis-Plus 如何实现连表查询的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

在项目开发中,难免会遇到连表查询的操作。

项目中用的是 MyBatis-Plus,是新使用的框架。官方文档看这里

我写过一篇通过单元测试来验证 MyBatis-Plus 的 CRUD 操作。点这里跳转

今天遇到连表查询的问题,特此记录一下。

遇到需要连表操作,想起 MyBatis 的操作连表查询,要是 MyBatis-Plus 也像 MyBatis 一样,就脑壳痛了。(MyBatis-Plus 是 MyBatis 的增强版)

脑壳痛归脑壳痛,先动手干。

首先

因为官方的内置接口方法都是针对单表的,所以要连表的话,还是得中规中矩来。

// 第一步,在 mapper.java 类中定义一个连表查询的方法 selectTsxxWsla
public interface WTsxxMapper extends SuperMapper<WTsxx> {
 List<Object> selectTsxxWsla();
}

// 第二步,在 mapper.xml 中定义 id='selectTsxxWsla' 的查询块
<mapper namespace="com.haoda.sswfw.dao.primary.mapper.WTsxxMapper">
 <select id="selectTsxxWsla" resultType="map">
 SELECT a.*,CONCAT(b.xxid,'') AS xxid,b.nr,b.xxbt,b.weixzt,b.ywlxbm,b.createtime,b.glid 
 FROM v_weix_user a,w_tsxx b 
 JOIN (
   SELECT xxid,user_name,createtime FROM w_tsxx_user
    ) c ON b.xxid = c.xxid 
 WHERE a.user_name = c.user_name AND a.openid != '' AND b.weixzt = '2' AND b.errcode IS NULL AND LOWER(b.ywlxbm) = 'wsla'
 </select>
</mapper>

// 第三步,直接写测试用例,看看能出来什么效果
@RunWith(SpringRunner.class)
@SpringBootTest
public class DbTest {
 @Autowired
 private WTsxxMapper tsxxMapper;
 
 @Test
 public void test3() {
 List<Object> selectTsxxWsla = tsxxMapper.selectTsxxWsla();
 for (Object obj : selectTsxxWsla) {
  System.out.println(obj);
 }
 }
}

 运行结果出来发现,select 语句中的字段都封装成 Object,存到 List 集合中去了,不过有一点就是如果字段的值是 null 的,就不会封到 Object 里。

有点小开心

回顾一下我上次在 MyBatis 的连表方式,首先我在主表的实体类中把需要连表的实体类加进去了。

然后在 mapper.xml 添加了 association 标签,用来配置关联关系的。

然后

我发现可以封装 Object,那我想是不是就可以自定义一个 VO 来封装成一个实体类。

// 将查询字段 自定义成 WxTsxxVo
public class WxTsxxVo {
 private String openid;
 private String unionid;
 private Long user_id;
 private String user_name;
 .....
}

// 原本 List<Object> 替换成 List<WxTsxxVo>
public interface WTsxxMapper extends SuperMapper<WTsxx> {
 List<WxTsxxVo> selectTsxxWsla();
}

// 原本 List<Object> 替换成 List<WxTsxxVo>
@Test
public void test3() {
 List<WxTsxxVo> selectTsxxWsla = tsxxMapper.selectTsxxWsla();
 for (WxTsxxVo obj : selectTsxxWsla) {
 System.out.println(obj);
 }
}

然后很开心运行了 test3,想着结果应该没问题的了,结果报错了,报了个转换异常,不能转换成 WxTsxxVo 对象。

不对啊,Object 都没有报错,我定义了个 WxTsxxVo 实体就报错了?

后来想想应该是查询出来的结果不认识我这个 WxTsxxVo,网上搜了一下「连表查询封装进自定义实体类」,看到有个解决方案是 添加association标签,还有另外一个解决方案是在 mapper.xml 中写一个对应的 resultMap

所以我选择尝试第二种方案。

运行成功

// 对应 WxTsxxVo 实体类,写了一个对应的 resultMap
<resultMap id="WxTsxxVo" type="com.haoda.sswfw.job.vo.WxTsxxVo">
   <result column="openid" property="openid" />
   <result column="unionid" property="unionid" />
   <result column="user_id" property="user_id" />
   <result column="user_name" property="user_name" />
   ...
</resultMap > 

// 原先的 resultType="map" 替换成 resultMap="WxTsxxVo"
<select id="selectTsxxWsla" resultMap="WxTsxxVo">
 SELECT a.*,CONCAT(b.xxid,'') AS xxid,b.nr,b.xxbt,b.weixzt,b.ywlxbm,b.createtime,b.glid 
 FROM v_weix_user a,w_tsxx b 
 JOIN (
   SELECT xxid,user_name,createtime FROM w_tsxx_user
   ) c ON b.xxid = c.xxid 
 WHERE a.user_name = c.user_name AND a.openid != '' AND b.weixzt = '2' AND b.errcode IS NULL AND LOWER(b.ywlxbm) = 'wsla'
</select>

再次运行,这次就成功了。查询出来的每条结果都封装成 WxTsxxVo,然后在放到 List 集合里面。

总结
1.新框架需要多点尝试,所以写测试用例就很重要了。
2.MyBatis 也许也能像上面一样,并不需要在主表的实体类里面关联另外一个实体,不过有机会还是可以试试看的。

到此这篇关于MyBatis-Plus 如何实现连表查询的示例代码的文章就介绍到这了,更多相关MyBatis-Plus 连表查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • 调用Mybatis plus中的saveBatch方法报找不到表的问题

    调用Mybatis plus中的saveBatch方法报找不到表的问题

    在用Mybatis plus开发的项目中,用自带的API批量保存的方法saveBatch操作时,发现报没有找到表的错误,本文就来详细的介绍一下解决方法,感兴趣的可以了解一下
    2024-03-03
  • 详解SpringCloud是如何动态更新配置的

    详解SpringCloud是如何动态更新配置的

    spring cloud在config配置管理的基础上,提供了consul config的配置管理和动态监听,那么这里面到底是怎样实现的,本文将为你揭秘,感兴趣的小伙伴可以跟着小伙伴一起来学习
    2023-06-06
  • java实现的日期时间转换工具类完整示例

    java实现的日期时间转换工具类完整示例

    这篇文章主要介绍了java实现的日期时间转换工具类,结合完整实例形式分析了java针对日期时间常见的转换、计算、格式化等相关操作与封装技巧,需要的朋友可以参考下
    2019-10-10
  • 如何解决Maven依赖无法导入的问题

    如何解决Maven依赖无法导入的问题

    本文介绍了如何通过在setting.xml中配置仓库坐标和在IntelliJ IDEA中进行相关设置来提高Maven下载Jar包的速度,首先在setting.xml中找到mirrors标签进行配置,然后在IntelliJ IDEA的设置中输入特定的命令
    2024-10-10
  • SpringBoot中使用Servlet三大组件的方法(Servlet、Filter、Listener)

    SpringBoot中使用Servlet三大组件的方法(Servlet、Filter、Listener)

    这篇文章主要介绍了SpringBoot中使用Servlet三大组件的方法(Servlet、Filter、Listener),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • 详解如何实现SpringBoot的底层注解

    详解如何实现SpringBoot的底层注解

    今天给大家带来的文章是如何实现SpringBoot的底层注解,文中有非常详细的介绍及代码示例,对正在学习java的小伙伴很有帮助,需要的朋友可以参考下
    2021-06-06
  • 集合框架(Collections Framework)详解及代码示例

    集合框架(Collections Framework)详解及代码示例

    这篇文章主要介绍了集合框架(Collections Framework)详解及代码示例,文章涉及集合数组的区别,collection接口,iterator迭代器,list接口及其用法,LinkedHashSet集合等有关内容,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • Java实现斗地主案例

    Java实现斗地主案例

    这篇文章主要为大家详细介绍了Java实现斗地主案例,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • Java的字符读写类CharArrayReader和CharArrayWriter使用示例

    Java的字符读写类CharArrayReader和CharArrayWriter使用示例

    这篇文章主要介绍了Java的字符读写类CharArrayReader和CharArrayWriter使用示例,两个类分别继承于Reader和Writer,需要的朋友可以参考下
    2016-06-06
  • java基于jdbc连接mysql数据库功能实例详解

    java基于jdbc连接mysql数据库功能实例详解

    这篇文章主要介绍了java基于jdbc连接mysql数据库功能,结合实例形式详细分析了jdbc连接mysql数据库的原理、步骤、实现方法及相关操作技巧,需要的朋友可以参考下
    2017-10-10

最新评论