本文链接地址: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. hbuilder打包app基本流程

    声明:本文可能用到一些工具和第三方网站,都是为了达到目的而使用的工具,绝不含有广告成分 1.下载.最新的Hbuilder X貌似不能直接创建移动app了(自己不会用),建议旧版.可去腾某讯软件中心下载 ...

  2. [BUUCTF]PWN——铁人三项(第五赛区)_2018_rop

    铁人三项(第五赛区)_2018_rop[32位libc泄露] 题目附件 解题步骤: 例行检查,32位,开启了NX保护 试运行一下程序,一开始让我们输入,然后直接输出"Hellow,world ...

  3. LuoguP7398 [COCI2020-2021#5] Šifra 题解

    Content 给定一个长度 \(n\) 的只包含小写字母和 \(0\sim9\) 的字符串(字符串中的字母可视为分隔符).求字符串中包含多少个不同的数字. 数据范围:\(1\leqslant n\l ...

  4. java 图形化小工具Abstract Window Toolit

      老掉牙的历史 Java1.0在发布的时候,就为我们提供了GUI操作的库,这个库系统在所有的平台下都可以运行,这套基本的类库被称作抽象窗口工具集(Abstract Window Toolit),简称 ...

  5. Java 数据类型:集合接口Map:HashTable;HashMap;IdentityHashMap;LinkedHashMap;Properties类读取配置文件;SortedMap接口和TreeMap实现类:【线程安全的ConcurrentHashMap】

    Map集合java.util.Map Map用于保存具有映射关系的数据,因此Map集合里保存着两个值,一个是用于保存Map里的key,另外一组值用于保存Map里的value.key和value都可以是 ...

  6. Tornado WEB服务器框架 Epoll-- 【模板】

    4.2 使用模板 1. 路径与渲染 使用模板,需要仿照静态文件路径设置一样,向web.Application类的构造函数传递一个名为template_path的参数来告诉Tornado从文件系统的一个 ...

  7. 使用JSONArray.fromObject转化list时,如果有集合属性,很容易出错,此刻把集合属性过滤掉便可

    使用JSONArray.fromObject转化list时,如果有集合属性,很容易出错,此刻把集合属性过滤掉便可

  8. ubuntu查系统信息及系统服务

    系统信息 uname -a               # 查看内核/操作系统/CPU信息 cat /etc/issue           # 查看操作系统版本 cat /proc/version ...

  9. 【LeetCode】1095. 山脉数组中查找目标值 Find in Mountain Array

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 二分查找 日期 题目地址:https://leetco ...

  10. 【LeetCode】954. Array of Doubled Pairs 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ...