首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MyBatis-多表查询(一对一

1、多表查询(一对一) 1.1、使用多表查询前的准备 学生表(students): 班级表(classes): 1.2、需求分析(一对一) 查询所有学生信息,关联查询下班级信息。...注意: 因为一个学生信息只能在一个班级里,所以从查询学生信息出发关联查询班级信息为一对一查询。 如果从班级信息出发查询班级下的学生信息则为一对多查询,因为一个班级可以有多个学生。...DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd...session.commit();; session.close(); in.close(); } } 3、案例实现-方式二 使用resultMap,定义专门的resultMap用于映射一对一查询结果...DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd

30210
您找到你想要的搜索结果了吗?
是的
没有找到

MyBatis之级联——一对一关系

在学数据库概论的时候会听到这么几个词:数据库的关系分为一对一、一对多、多对多。对于在学校里学的知识已经忘得差不多了,在这里简单的提一下数据库的关系。...此篇是介绍MyBatis是如何实现数据库中一对一关系的,我们就暂且先介绍一对一关系。所谓一对一关系其实在生活中很常见,比如一个学生有且只对应一个属于他的学生证。下面就是我们的所假设的数据库物理模型。...association一对一级联。...,在第10行代码中我们使用MyBatis提供的assocation关键字来表示它们是一对一的关系。...好了,到现在为止,我们就实现了数据库中的一对一级联关系。接下来就是数据库中一对多级联。

56350

MyBatis-20MyBatis高级结果映射【一对一映射(4种方式)】

文章目录 概述 需求 方式一:使用自动映射处理一对一映射 实体类改造 UserMapper接口增加接口方法 UserMapper.xml增加SQL 单元测试 方式二:使用resultMap配置一对一映射...-- 使用resultMap配置一对一映射 --> <resultMap id="userRoleMap" type="com.artisan.<em>mybatis</em>.xml.domain.SysUser...---- 方式三:使用resultMap的asscociation标签配置<em>一对一</em>映射 在resultMap中,association标签用于和一个复杂的类型进行关联,即用于<em>一对一</em>的关联配置。...-- 使用resultMap配置<em>一对一</em>映射 使用association --> <resultMap id="roleMap" type="com.artisan.<em>mybatis</em>.xml.domain.SysRole...如果不加的话,<em>MyBatis</em>会默认添加调用者当前命名空间的前缀。

63130

MyBatis 实现一对一关联查询的多种方式

一对一关联查询是其中一种常见的需求,它允许我们在两个表之间建立一对一的关系,以便在查询时将相关数据合并在一起。...在本篇博客中,我将介绍如何使用 MyBatis 实现一对一关联查询,并详细讨论多种实现方式。...接下来,让我们看看如何使用 MyBatis 实现一对一关联查询的多种方式。...然后,我们可以在代码中分别调用这两个查询,并将结果合并在一起,从而实现一对一关联查询。方式三:使用嵌套结果MyBatis 还提供了一种更简洁的方式来实现一对一关联查询,即使用嵌套结果。...结论在本篇博客中,我们讨论了如何使用 MyBatis 实现一对一关联查询的多种方式。不同的方式适用于不同的场景,您可以根据具体需求选择最合适的方法。

47640

MyBatis初级实战之五:一对一关联查询

对上述两种查询的支持,全文由以下章节组成: 准备数据; 本次实战的java工程 最简单的联表(两个表的数据保存在一个实体类的不同字段); 一对一联表查询(两个表的数据分别保存在不同实体类,假设是A和B,...A是B的成员变量) 一对一嵌套查询(两个表的数据分别保存在不同实体类,假设是A和B,A是B的成员变量) 源码下载 如果您不想编码,可以在GitHub下载所有源码,地址和链接信息如下表所示(https:/...成功取得LogExtend实例: [在这里插入图片描述] 下一站是一对一联表查询; 关于一对一关联的两种方式 前面的查询有个特点:尽管查询了两个表,但结果都在同一实体类的不同字段,而更符合业务逻辑的关系应该是...查询得到上述LogAssociateUser 类型的结果; 一对一关联的实现有联表和嵌套查询两种,它们的差异在Mybatis中体现在association的子节点上: 联表时,association内使用...result子节点,将联表查询的结果映射到关联对象; 嵌套时,association内使用select子节点,触发一次新的查询; 一对一(联表) 所谓一对一,就是一个对象关联了另一个对象,例如一条log

96800

MyBatis初级实战之五:一对一关联查询

对上述两种查询的支持,全文由以下章节组成: 准备数据; 本次实战的java工程 最简单的联表(两个表的数据保存在一个实体类的不同字段); 一对一联表查询(两个表的数据分别保存在不同实体类,假设是A和B,...A是B的成员变量) 一对一嵌套查询(两个表的数据分别保存在不同实体类,假设是A和B,A是B的成员变量) 源码下载 如果您不想编码,可以在GitHub下载所有源码,地址和链接信息如下表所示(https:/...成功取得LogExtend实例: 下一站是一对一联表查询; 关于一对一关联的两种方式 前面的查询有个特点:尽管查询了两个表,但结果都在同一实体类的不同字段,而更符合业务逻辑的关系应该是log类中有个...查询得到上述LogAssociateUser 类型的结果; 一对一关联的实现有联表和嵌套查询两种,它们的差异在Mybatis中体现在association的子节点上: 联表时,association内使用...result子节点,将联表查询的结果映射到关联对象; 嵌套时,association内使用select子节点,触发一次新的查询; 一对一(联表) 所谓一对一,就是一个对象关联了另一个对象,例如一条log

1.1K40

MyBatis嵌套查询 - 一对一 - 一对多

MyBatis嵌套查询 - 一对一 - 一对多 前言 在上一篇中我们已经基本认识了 MyBatis 的多表查询了。那么 MyBatis 还有一个比较有意思的功能,就是 嵌套查询。...一对一【嵌套查询】 需求 需求:查询一个订单,与此同时查询出该订单所属的用户 sql语句 -- 1.根据订单id查询订单表 select * from orders where id = 1; --...DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd...DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis...通过mybatis进行嵌套组合 看 OrderMapper.xml里的嵌套设置 一对一在结果映射 resultMap 中使用 association 进行嵌套查询,column 为传递的从 Orders

1.8K21
领券