本文链接地址:mybatis关联查询基础----高级映射(一对一,一对多,多对多)

前言:
今日在工作中遇到了一个一对多分页查询的问题,主表一条记录对应关联表四条记录,关联分页查询后每页只显示三条记录,sql查询主表一条记录的时候,加上关联表后主表每一条记录都和关联表相对应,也就是说主表一条记录和关联表四条对应实际查出的是4条,怎么实现主表一条记录和关联表多条数据关联后查出后是一条信息呢?(下面一对多详解),所以想将关于mybatis多表查询的问题整理记录下来,希望大家多多补充指正。
0.首先是三个对象(为了方便理解用了三个比较简单的对象):





一、一对一(以学生和学生信息为例,通过学号关联):

1.1相对来说一对一就比较简单学生表通过学号和学生信息表关联



注意:如果主表和关联表有字段重复,则需要查询语句中起别名,将别名写入在column属性中,因为起别名是对数据库字段起的别名,所以要写在数据库所对应的的字段上,别名自动就和实体类对应了。

二、一对多(学生表和学生成绩表)

当关联查询的时候需要分成两种情况,分页和不分页


2.1一对多不分页(写法和一对一一样只是将association 标签换成了collection )

   <resultMap id="BaseResultMap" type="com.qike.coldKu.entity.Student">
<id column="id" property="id" jdbcType="INTEGER"/>
<result column="name" property="name" jdbcType="VARCHAR"/>
<result column="num" property="num" jdbcType="INTEGER"/>
<!--一对一-->
<association property="studentInfo" javaType="com.qike.coldKu.entity.StudentInfo">
<result column="id" property="id" jdbcType="INTEGER"/>
<result column="age" property="age" jdbcType="INTEGER"/>
<result column="phone" property="phone" jdbcType="VARCHAR"/>
<result column="stuNum" property="stuNum" jdbcType="VARCHAR"/>
</association>
<!--一对多不分页-->
<collection property="stuGradeList" ofType="com.qike.coldKu.entity.StuGrade" >
<result column="stuNum" property="stuNum" jdbcType="VARCHAR"/>
<result column="Chinese" property="Chinese" jdbcType="VARCHAR"/>
<result column="mathematics" property="mathematics" jdbcType="VARCHAR"/>
</collection>
</resultMap>

2.2一对多分页(如果关联查询涉及到分页,则需要用到myBatils的一种映射规则)

当用分页插件PageHelper.startPage(pageCurrent,pageSize);进行分页时用第一种方式发现返回的数据变少了,前言中大体提了下原因,下面写一下具体的解决方式:

 <resultMap id="BaseResultMap" type="com.qike.coldKu.entity.Student">
<id column="id" property="id" jdbcType="INTEGER"/>
<result column="name" property="name" jdbcType="VARCHAR"/>
<result column="num" property="num" jdbcType="INTEGER"/>
<!--一对一-->
<association property="studentInfo" javaType="com.qike.coldKu.entity.StudentInfo">
<result column="id" property="id" jdbcType="INTEGER"/>
<result column="age" property="age" jdbcType="INTEGER"/>
<result column="phone" property="phone" jdbcType="VARCHAR"/>
<result column="stuNum" property="stuNum" jdbcType="VARCHAR"/>
</association>
<!--一对多不分页-->
<collection property="stuGradeList" ofType="com.qike.coldKu.entity.StuGrade" >
<result column="stuNum" property="stuNum" jdbcType="VARCHAR"/>
<result column="Chinese" property="Chinese" jdbcType="VARCHAR"/>
<result column="mathematics" property="mathematics" jdbcType="VARCHAR"/>
</collection>
<!--一对多分页 这个地方没有属性的映射了 select指的是映射执行查询的名字 column指的是传参-->
<collection property="coldkuExpands" ofType="com.qike.coldKu.entity.ColdkuExpand" select="queryList" column="num"> </collection>
</resultMap>

sql写法

<select id="queryUserInfo"  resultMap="BaseResultMap">
select a.name as name,a.num from student as a
</select>
<select id="queryStuGrade" resultType="com.qike.coldKu.entity.StuGrade" parameterType="int">
select * from StuGrade where stuNum = #{num}
</select>

mybatis关联查询基础----高级映射的更多相关文章

  1. MyBatis基础:MyBatis关联查询(4)

    1. MyBatis关联查询简介 MyBatis中级联分为3中:association.collection及discriminator. ◊ association:一对一关联 ◊ collecti ...

  2. MyBatis关联查询、多条件查询

    MyBatis关联查询.多条件查询 1.一对一查询 任务需求; 根据班级的信息查询出教师的相关信息 1.数据库表的设计 班级表: 教师表: 2.实体类的设计 班级表: public class Cla ...

  3. mybatis 关联查询实现一对多

    场景:最近接到一个项目是查询管理人集合  同时每一个管理人还存在多个出资人   要查询一个管理人列表  每个管理人又包含了出资人列表 采用mybatis关联查询实现返回数据. 实现方式: 1 .在实体 ...

  4. MyBatis关联查询和懒加载错误

    MyBatis关联查询和懒加载错误 今天在写项目时遇到了个BUG.先说一下背景,前端请求更新生产订单状态,后端从前端接收到生产订单ID进行查询,然后就有问题了. 先看控制台报错: org.apache ...

  5. Mybatis关联查询和数据库不一致问题分析与解决

    Mybatis关联查询和数据库不一致问题分析与解决 本文的前提是,确定sql语句没有问题,确定在数据库中使用sql和项目中结果不一致. 在使用SpringMVC+Mybatis做多表关联时候,发现也不 ...

  6. MyBatis关联查询,一对多关联查询

    实体关系图,一个国家对应多个城市 一对多关联查询可用三种方式实现: 单步查询,利用collection标签为级联属性赋值: 分步查询: 利用association标签进行分步查询: 利用collect ...

  7. Mybatis关联查询之二

    Mybatis关联查询之多对多 多对多 一.entity实体类 public class Student { private Integer stuid; private String stuname ...

  8. mybatis入门基础----高级映射(一对一,一对多,多对多)

    阅读目录 一:订单商品数据模型 二.一对一查询 三.一对多查询 四.多对多查询 回到顶部 一:订单商品数据模型 1.数据库执行脚本 创建数据库表代码: CREATE TABLE items ( id ...

  9. MyBatis关联查询 (association) 时遇到的某些问题/mybatis映射

    先说下问题产生的背景: 最近在做一个用到MyBatis的项目,其中有个业务涉及到关联查询,我是将两个查询分开来写的,即嵌套查询,个人感觉这样更方便重用: 关联的查询使用到了动态sql,在执行查询时就出 ...

随机推荐

  1. 【CF1591】【数组数组】【逆序对】#759(div2)D. Yet Another Sorting Problem

    题目:Problem - D - Codeforces 题解 此题是给数组排序的题,操作是选取任意三个数,然后交换他们,确保他们的位置会发生改变. 可以交换无限次,最终可以形成一个不下降序列就输出&q ...

  2. 日历优先级(Project)

    <Project2016 企业项目管理实践>张会斌 董方好 编著 好了,这下我们一共有三个日历了:"项目日历"(默认的日历)."任务日历"(与任务关 ...

  3. 『学了就忘』Linux系统定时任务 — 89、任务调度工具anacron

    目录 1.任务调度工具anacron介绍 2.新旧版本Linux中anacron工具的区别 3./etc/cron.{daily,weekly,monthly}目录说明 4.anacron命令 5./ ...

  4. python enumerate枚举用法总结

    enumerate()说明 enumerate()是python的内置函数enumerate在字典上是枚举.列举的意思对于一个可迭代的(iterable)/可遍历的对象(如列表.字符串),enumer ...

  5. Spring Boot应用程序启动器

    官网地址:https://docs.spring.io/spring-boot/docs/2.1.12.RELEASE/reference/html/using-boot-build-systems. ...

  6. qt5读取所有本机IP

    说明 需要添加 network模块 本文介绍的函数将读取所有本机IP,包括 ipv4和ipv6 本文演示版本 qt5.14 头文件 #include <QHostAddress> #inc ...

  7. c++内存分布之纯虚函数

    关于 本文演示环境:VS2017+32位程序. 纯虚函数是一种特殊的虚函数.可以预测到:虚函数的结论同样适用纯虚函数,但是纯虚函数是一种特殊的存在,还是看看实际结果. 代码写的不够规范: 因为任何带虚 ...

  8. UVA11754 - Code Feat

    Hooray!  Agent Bauer has shot the terrorists, blown upthe bad guy base, saved the hostages, exposed ...

  9. Codeforce 633C. Spy Syndrome 2

    C. Spy Syndrome 2 time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...

  10. 解决"The remote SSH server rejected X11 forwarding request"问题

    今天突然想起来好久没有登录我的vps了,于是下载了xshell,填入地址登录后,看到提示"WARNING! The remote SSH server rejected X11 forwar ...