Mybatis中级联有关联(association).集合(collection).鉴别器(discriminator)三种.其中,association对应一对一关系.collection对应一对多关系.discriminator可以根据情况选择采用哪个类作为实例,关联不同的结果集. 一.关联 Mybatis的关联有两种方式: 嵌套查询:通过执行另外一个 sql映射语句来返回预期的复杂类型 嵌套结果:使用嵌套结果映射来处理重复了联合结果的子集 场景一:一个部门Department有一个部门经理…
知识点:查询一个实体类,并查出这个类下面的集合 Employee.java实体类 package com.hand.mybatis.bean;public class Employee {    private Integer eId;    private String eName;    private Integer gender;    private String email;    private Department dept;        public Employee() {…
级联是一个数据库实体的概念.一对多的级联,一对多的级联,在MyBatis中还有一种被称为鉴别器的级联,它是一种可以选择具体实现类的级联. 级联不是必须的,级联的好处是获取关联数据十分便捷,但是级联过多会增加系统的复杂度,同时降低系统的性能,此增彼减,所以当级联的层级超过3层时,就不要考虑使用级联了,因为这样会造成多个对象的关联,导致系统的耦合.复杂和难以维护.在现实的使用过程中,要根据实际情况判断是否需要使用级联. MyBatis中的级联 MyBatis的级联分为3种. •鉴别器(discrim…
mybatis的关联映射一对一一对多多对多 一.一对一(一个人只能有一个身份证号) 1.创建表创建表tb_card CREATE TABLE `tb_card` ( `id` int(11) NOT NULL AUTO_INCREMENT, `code` varchar(20) DEFAULT NULL, PRIMARY KEY (`id`) ) INSERT INTO tb_card(CODE)VALUES('150421178702260614'); 创建表tb_person CREATE…
一.一对一关联 1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数据 创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就是一种一对一的关系. CREATE TABLE teacher( t_id INT PRIMARY KEY AUTO_INCREMENT, t_name ) ); CREATE TABLE class( c_id INT PRIMARY KEY AUTO_INCREMENT, c_name ), teacher_i…
一.一对一关联 1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数据 创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就是一种一对一的关系. 1 CREATE TABLE teacher( 2 t_id INT PRIMARY KEY AUTO_INCREMENT, 3 t_name VARCHAR(20) 4 ); 5 CREATE TABLE class( 6 c_id INT PRIMARY KEY AUTO_INCREMEN…
原文:http://www.cnblogs.com/xdp-gacl/p/4264440.html 一.一对一关联 1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数据 创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就是一种一对一的关系. CREATE TABLE teacher( t_id INT PRIMARY KEY AUTO_INCREMENT, t_name ) ); CREATE TABLE class( c_id I…
原文链接:http://www.cnblogs.com/xdp-gacl/p/4264440.html 一.一对一关联 1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数据 创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就是一种一对一的关系. CREATE TABLE teacher( t_id INT PRIMARY KEY AUTO_INCREMENT, t_name ) ); CREATE TABLE class( c_id…
在上章的 一对多 中,我们已经学习如何在 Mybatis 中关联多表,但在实际项目中也是经常使用 多对一 的情况,这些查询是如何处理的呢,在这一节中我们来学习它.多表映射的多对一关系要用到 mybitis 的 association 来加以实现.这篇介绍的是多表中的多对一表关联查询. 应用场景:首先根据帖子 ID 读取一个帖子信息,然后再读取这个帖子所属的用户信息. 1.先做一些准备工作 我们首先在创建一个 java 工程,工程名称为:mybatis05-many2one(下载),还需要创建两张…
关联.多对一关联查询 package org.mybatis.example.dao; import java.util.Date; //雇员类 public class Emp { private Integer empno; private String ename; private String job; private Integer mgr; private Date hiredate; private Integer sal; private Integer comm; privat…
前言 实际开发项目中,很少是针对单表操作,基本都会联查多表进行操作,尤其是出一些报表的内容.此时,就可以使用Mybatis的关联查询还有动态SQL.前几篇文章已经介绍过了怎么调用及相关内容,因此这里只说明核心内容SQL映射文件的配置. 一对一关联 <association /> JavaType是用来指定pojo中属性的类型此处采用两种方式进行关联查询,一种是嵌套结果,一种是嵌套查询. <!-- 根据班级id查询班级和教师信息 --> <select id="get…
一.一对一关联 1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数据 创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就是一种一对一的关系. CREATE TABLE teacher( t_id INT PRIMARY KEY AUTO_INCREMENT, t_name ) ); CREATE TABLE class( c_id INT PRIMARY KEY AUTO_INCREMENT, c_name ), teacher_i…
转:Mybatis系列之集合映射 上篇文章我们讲了关联映射,实现了销售与登录用户之间的关联.本文我们接着来讲一讲集合映射,实现销售与客户的多对多关系. 实现销售与客户多对多关系 本文中仍延用<Mybatis系列之关联映射>中的映射接口和测试用例,这里仅对增加和修改的内容进行讲解. 第一步,在动手编写映射文件之前,我们需要对Sales类增加一个List属性,用以保存销售员对应的客户列表. /** * */ private List<Customer> customers; publi…
1.#{}和${}的区别是什么? ${}是Properties文件中的变量占位符,它可以用于标签属性值和sql内部,属于静态文本替换,比如${driver}会被静态替换为com.mysql.jdbc.Driver.#{}是sql的参数占位符,Mybatis会将sql中的#{}替换为?号,在sql执行前会使用PreparedStatement的参数设置方法,按序给sql的?号占位符设置参数值,比如ps.setInt(0, parameterValue),#{item.name}的取值方式为使用反射…
笔记要点出错分析与总结工程组织 1.定义接口 interface DepartmentMapper package com.dao; import com.bean.Department; public interface DepartmentMapper { public Department getDeptByIdStep(Integer id); //使用Collection,执行分步查询 } interface EmployeeMapperPlus package com.dao; im…
系列博文: JavaWeb_(Mybatis框架)JDBC操作数据库和Mybatis框架操作数据库区别_一 传送门 JavaWeb_(Mybatis框架)使用Mybatis对表进行增.删.改.查操作_二   传送门 JavaWeb_(Mybatis框架)Mapper动态代理开发_三  传送门 JavaWeb_(Mybatis框架)主配置文件介绍_四    传送门 JavaWeb_(Mybatis框架)输入和输出参数_五  传送门 JavaWeb_(Mybatis框架)关联查询_六传送门 传送门…
mybatis级联的实现 开篇         级联有三种对应关系: 1.一对一(association):如学号与学生  2.一对多(collection):如角色与用户  3.多对多(discriminator):如一个角色可以对应多个用户,一个用户也可以兼任多个角色 下面做一个一对多级联 数据库表描述:(使用的是derby数据库) user表中的role_id 对应role表中的id,一个用户对应一个角色,一个角色对应多个用户. standard_user表: role表: 1.使用上篇分…
mybatis 一对一关联 association 返回空值 最近学习spring mvc + mybatis开发,看的书是<Spring MVC+Mybatis开发 从入门到精通>,在学习一对一关联,并且延迟加载一节的时候,使用书上讲解的例子无法调通,主要代码问题是在mapper.xml文件中,部分如下: <resultMap id="BaseResultMap" type="com.pp.entity.SysUser"> <id c…
SpringBoot+Mybatis实现关联查询 今天学习了下Mybatis的动态查询,然后接着上次的Demo改造了下实现表的关联查询. 话不多说,开始今天的小Demo 首先接着上次的项目 https://www.cnblogs.com/Leslie-/p/9469045.html 然后呢我们在数据库中创建新的两张表 如下图所示: 然后呢,关联查询当然要在User表里面添加新的属性 接下来 在项目中添加Car的实体类以及address的实体类 package com.example.demo.e…
Java基础-SSM之mybatis一对一关联 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.准备测试环境(创建数据库表)  1>.创建husbands和wifes表并建立关联关系(外键约束)  use yinzhengjie; )) ; )) ; alter table wifes add constraint fk_id foreign key (id) references husbands(id) ; 2>.添加Maven依赖 <?xml version=…
项目工程结构如下: 1. 搭建MyBatis框架环境 首先需要引入两个包:mybatis.jar 和 sqljdbc42.jar包 若分页需要导入两个包:pagehelper-5.1.0.jar 和  jsqlparser-1.0.jar 设置 mybatis 配置文件:SqlMapConfig.xml, 在 src目录下建立此文件,内容如下: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE con…
关联有嵌套查询和嵌套结果两种方式,本文是按照嵌套结果这种方式来说明的 上一章介绍了多对一的关系,用到了<association></association>,这是一个复杂类型的关联.我们选择一个示例来回顾下,比如:一个博客有一个用户,关联映射就工作于这种结果之上.首先看下,我们在本文中要用到的表结构字段: 博客 blog : id title author_id 作者 author: id username password email bio favourite_section…
场景:查询部门的同时,要求查询此部门下的所有用户. 部门(Department) private Integer id; private String departmentName; private List<Blogger> bloggers;//关联List集合.部门下所有bloggers 用户(Blogger) private Integer id; private String username; private String password; private String prof…
一.鉴别器和一对多级联 1.完善体检表,分为男雇员体检和女雇员体检表 (1)持久层dao编写 package com.xhbjava.dao; import com.xhbjava.domain.MaleHealthForm; /** * 男性体检表 * @author Mr.wang *@date 2020年2月27日 */ public interface IMaleHealthFormDao { public MaleHealthForm getMaleHealthForm(Long em…
后台系统中 涉及到添加试卷 问题 答案的一个模块的.我需要通过试卷 查询出所有的试题,以及试题的答案.这个主要要使用到Mybatis的级联查询. 通过试卷 查询出与该试卷相关的试题(一对多),查询出试题的答案及分数(一对多). SelfTestTitle 实体类,SelfTestQuestion实体类,SelfTestAnswer实体类. package org.system.entity.self; import java.util.List; import org.core.entity.B…
mybatis中有时候表不能都分成单表进行查询,表之间会有联系,这时候需要将表进行级联 下面讲一下如何将mybatis中 的表进行级联.映射表关系如下 1:创建数据表 DROP TABLE IF EXISTS t_female_health_form; DROP TABLE IF EXISTS t_male_health_form; DROP TABLE IF EXISTS t_task; DROP TABLE IF EXISTS t_work_card; DROP TABLE IF EXIST…
有了前面几章的基础,对一些简单的应用是可以处理的,但在实际项目中,经常是关联表的查询,比如:最常见到的多对一,一对多等.这些查询是如何处理的呢,这一讲就讲这个问题.前面几篇教程中介绍的都是单表映射的一些操作,然而在我们的实际项目中往往是用到多表映射.在Java实体对象对中,一对多可以根据List和Set来实现,两者在mybitis中都是通过collection标签来配合来加以实现.这篇介绍的是多表中的多对一表关联查询. 应用场景:首先根据用户 ID 读取一个用户信息,然后再读取这个用户所发布贴子…
主要是对之前学习的关联映射做一个案例,自己动手实践一下,可以理解的更好一点. 开发环境 开发工具:idea Java环境: jdk1.8.0_121 数据库:SQLServer 项目结构,里面包含了三种关联映射的文件,会分别进行测试: 完整的mybatis-config.xml文件,MybatisUtils工具类和db.properties文件 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE co…
实际的开发中,对数据库的操作常常会涉及到多张表,这在面向对象中就涉及到了对象与对象之间的关联关系.针对多表之间的操作,MyBatis提供了关联映射, 通过关联映射就可以很好的处理对象与对象之间的关联关系. 1.1 关联关系概述 在关系型数据库中,多表之间存在着三种关联关系,分别为一对一.一对多和多对多,如下图所示: 三种关系如下: 一对一:在任意一方引入对方主键作为外键. 一对多:在"多"的一方,添加"一"的一方的主键作为外键. 多对多:产生中间关系表,引入两张表的…
传入集合list // 账户类型包括门店和分公司 List<Object> scopeList = new ArrayList<Object>(); scopeList.add(UserConstants.UserScope.STORE); scopeList.add(UserConstants.UserScope.BRANCH_COMPANY); params.put("scopeList", scopeList); PageResult<UserDto…