热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

mybatis表1对多查询

在用mybatis写mysql语句时,遇到了1对多关系的问题先看看关系:以A表为基础查询,A表一条记录对应B表的一条记录,

在用mybatis写mysql语句时,遇到了1对多关系的问题

先看看关系:
这里写图片描述
以A表为基础查询,A表一条记录对应B表的一条记录,而A表的一条记录对应C表的n条记录,然后B表和c表是1对1的关系。这时候的查询语句为:



<mapper namespace&#61;"mapper.AMapper"><resultMap id&#61;"AMap" type&#61;"dto.A"><id column&#61;"A_ID" property&#61;"AId" jdbcType&#61;"DECIMAL" javaType&#61;"Long" /><result column&#61;"B_ID" property&#61;"BId" jdbcType&#61;"DECIMAL" javaType&#61;"Long" /><association property&#61;"B" javaType&#61;"dto.B"><id column&#61;"t_B_id" property&#61;"BId" jdbcType&#61;"DECIMAL" javaType&#61;"Long" />association><collection property&#61;"C" javaType&#61;"java.util.List" ofType&#61;"dto.C"><id column&#61;"C_C_ID" property&#61;"CId" jdbcType&#61;"DECIMAL" javaType&#61;"Long" /><result column&#61;"C_A_ID" property&#61;"AId" jdbcType&#61;"DECIMAL" javaType&#61;"Long" /><association property&#61;"C_B" javaType&#61;"dto.B"><id column&#61;"u_B_id" property&#61;"BId" jdbcType&#61;"DECIMAL" javaType&#61;"Long" />association>collection>resultMap><select id&#61;"selectA_WithC_ById" parameterType&#61;"java.lang.Long" resultMap&#61;"AMap">SELECT *FROMA LEFT JOINBONA.A_ID &#61; B.B_idLEFT JOINCONC.C_ID &#61; A.A_IDLEFT JOINB c_bONC.C_ID &#61; c_b.B_idWHEREA.A_ID &#61; #{id}select>
mapper>

查询原理&#xff1a;
这里写图片描述


注意&#xff1a;因为表会重复&#xff0c;所以相同的表&#xff0c;要起别名。同样的&#xff0c;相同的列名也要起别名&#xff0c;不然会出错的。还有一个问题&#xff0c;这个语句直接拿去mysql里面运行&#xff0c;和在项目里面运行&#xff0c;得到的结果条数可能不一样&#xff0c;因为在项目里面&#xff0c;已经把重复的数据和为一条&#xff0c;把不同的存入list中了。


这个有点复杂&#xff0c;但是慢慢的写就可以写好了&#xff0c;还好我写的时候没有报错。


推荐阅读
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • flowable工作流 流程变量_信也科技工作流平台的技术实践
    1背景随着公司业务发展及内部业务流程诉求的增长,目前信息化系统不能够很好满足期望,主要体现如下:目前OA流程引擎无法满足企业特定业务流程需求,且移动端体 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
author-avatar
herogan
这个家伙很懒,什么也没留下!
RankList | 热门文章