MyBatis关联关系
1、一对多:一个国家对应多个城市
01.实体类
package cn.pb.bean; import java.util.Set; /**
* 国家的实体类
*/
public class Country {
private Integer cId;//国家的编号
private String cName;//国家的名称 //关联省会的属性
private Set<Provincial> provincials; public Integer getcId() {
return cId;
} public void setcId(Integer cId) {
this.cId = cId;
} public String getcName() {
return cName;
} public void setcName(String cName) {
this.cName = cName;
} public Set<Provincial> getProvincials() {
return provincials;
} public void setProvincials(Set<Provincial> provincials) {
this.provincials = provincials;
} public Country(Integer cId, String cName, Set<Provincial> provincials) {
this.cId = cId;
this.cName = cName;
this.provincials = provincials;
}
public Country() { } @Override
public String toString() {
return "Country{" +
"cId=" + cId +
", cName='" + cName + '\'' +
", provincials=" + provincials +
'}';
}
}
package cn.pb.bean; /**
* 省会对应的实体类
*/
public class Provincial {
private Integer pId; //省会的编号
private String pName; //省会名称 public Integer getpId() {
return pId;
}
public void setpId(Integer pId) {
this.pId = pId;
}
public String getpName() {
return pName;
}
public void setpName(String pName) {
this.pName = pName;
}
public Provincial(Integer pId, String pName) {
super();
this.pId = pId;
this.pName = pName;
}
public Provincial() {
super();
}
@Override
public String toString() {
return "Provincial [pId=" + pId + ", pName=" + pName + "]";
}
}
02.创建对应的dao和mapper文件
public interface CountryDao {
/**
* 根据国家的id查询出国家的信息 以及国家下面的省会信息
*/
Country selectCountryById(Integer cId);
}
03.mapper.xm文件=====单条SQL不能使用延迟加载
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.bdqn.dao.CountryDao"> <!-- 这里的resultMap和之前使用的不一样,哪怕属性和字段一致 也要书写
因为mybatis在底层封装的时候,是根据我们resultMap中写的属性来的 -->
<resultMap type="Country" id="countryMap">
<id property="cId" column="cid"/>
<result property="cName" column="cname"/>
<!-- 设置关联的集合属性 -->
<collection property="provincials" ofType="Provincial">
<id property="pId" column="pid"/>
<result property="pName" column="pname"/>
</collection>
</resultMap>
<!-- 这是单表的关联查询 不经常使用 因为 不能使用延迟加载 -->
<select id="selectCountryById" resultMap="countryMap">
select cid,cname,pid,pname from country,provincial
where cid=countryid and cid=#{xxx} <!--#{xxx} 参数的占位符 -->
</select>
</mapper>
04.mapper.xm文件=====多条SQL可以使用延迟加载
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.xdf.dao.CountryDao"> <!--必须是对应的dao接口的全类名--> <!--01 根据国家的编号 查询出 国家的信息 xxx就是用户输入的值-->
<select id="selectCountryById" resultMap="countryMap">
select cid,cname from country where cid=#{xxx}
</select>
<!--02 根据国家的编号 查询出 国家对应的省会信息 xxx 谁给传值-->
<select id="selectProvincialByCid" resultType="Provincial">
select pid,pname from provincial where countryid=#{xxx}
</select> <!--对应的countryMap 这种方式 推荐使用 因为使用使用延迟加载-->
<resultMap id="countryMap" type="Country">
<id property="cId" column="cid"/>
<result property="cName" column="cname"/>
<!--
select: 指的是关联sql语句的id ===》根据国家的编号 查询出 国家对应的省会信息的sql
column:关联sql语句需要的参数
-->
<collection property="provincials" ofType="Provincial"
select="selectProvincialByCid" column="cid"/>
</resultMap> </mapper>
05.在MyBatis.xml文件中 管理Mapper文件
<!-- 加载映射文件信息 -->
<mappers>
<mapper resource="cn/bdqn/dao/CountryMapper.xml" />
</mappers>
06.测试类代码
public class CountryTest { CountryDao dao=null;
SqlSession session=null;
Logger log=Logger.getLogger(CountryTest.class);
/**
* 在所有的test测试方法执行之前 都要执行的操作
*/
@Before
public void before(){
//获取session
session= SessionFactoryUtil.getSession();
dao=session.getMapper(CountryDao.class); //获取执行的类对象
} @After
public void after(){
if (session!=null){
session.close();
}
} /**
* 根据国家的编号 查询出 国家对应省会的信息
* 没有延迟加载
*/
@Test
public void selectCountry(){
Country country = dao.selectCountryById(1);
log.debug(country);
}
/**
* 根据国家的编号 查询出 国家对应省会的信息
* 设置延迟加载
*01.在mybati核心配置文件中 增加setting节点
*02.节点中增加
* <setting name="lazyLoadingEnabled" value="true"/>
* <setting name="aggressiveLazyLoading" value="false"/>
*/
@Test
public void selectCountryLazy(){
Country country = dao.selectCountryById(2);
log.debug(country.getcName()); //只查询国家的名称 如果开启了延迟加载有1条sql
log.debug(country.getcName()); //只查询国家的名称 如果没开启了延迟加载有2条sql
log.debug(country.getProvincials()); //查询国家对应的省会 无论有没有开启了延迟加载都有2条sql
} }
07.在MyBatis.xml中核心配置文件中的配置延迟加载
<settings>
<!--开启延迟加载 默认值是 false-->
<setting name="lazyLoadingEnabled" value="true"/>
<!--
我们的一个实体类中可以有多个延迟加载属性不?? 肯定可以!
当启用后,一个有延迟加载属性的对象的任何一个延迟属性被加载时,该对象的所有的属性都会被加载。
否则,所有属性都是按需加载。默认值是true
-->
<setting name="aggressiveLazyLoading" value="false"/>
</settings>
2、多对一:多个城市对应一个国家
01.实体类
package cn.pb.bean; /**
* 国家的实体类
*/
public class Country { private Integer cId; //国家的编号
private String cName; //国家的名称 public Integer getcId() {
return cId;
}
public void setcId(Integer cId) {
this.cId = cId;
}
public String getcName() {
return cName;
}
public void setcName(String cName) {
this.cName = cName;
}
public Country(Integer cId, String cName) {
super();
this.cId = cId;
this.cName = cName;
}
public Country() {
super();
}
@Override
public String toString() {
return "Country [cId=" + cId + ", cName=" + cName ;
} }
package cn.pb.bean; /**
* 省会对应的实体类
*/
public class Provincial {
private Integer pId; //省会的编号
private String pName; //省会名称
//关联的国家属性
private Country country; public Country getCountry() {
return country;
}
public void setCountry(Country country) {
this.country = country;
}
public Integer getpId() {
return pId;
}
public void setpId(Integer pId) {
this.pId = pId;
}
public String getpName() {
return pName;
}
public void setpName(String pName) {
this.pName = pName;
}
public Provincial(Integer pId, String pName) {
super();
this.pId = pId;
this.pName = pName;
}
public Provincial() {
super();
}
@Override
public String toString() {
return "Provincial [pId=" + pId + ", pName=" + pName + ", country="
+ country + "]";
} }
02.创建对应的dao和mapper文件
public interface CountryDao {
/**
* 根据省会的id 查询出 省会 以及对应的国家
*/
Provincial selectProvincialById(Serializable id);
}
03.mapper.xm文件=====单条SQL不能使用延迟加载
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.pb.dao.ProvincialDao">
<resultMap id="provincialMap" type="Provincial">
<id property="pId" column="pid"/>
<result property="pName" column="pname"/>
<!-- 设置关联的属性 -->
<association property="country" javaType="Country">
<id property="cId" column="cid"/>
<result property="cName" column="cname"/>
</association>
</resultMap>
<!-- 这是单表的关联查询 不经常使用 因为 不能使用延迟加载 -->
<select id="selectProvincialById" resultMap="provincialMap">
select cid,cname,pid,pname from country,provincial
where cid=countryid and pid=#{xxx} <!-- #{xxx} 参数的占位符 -->
</select>
</mapper>
04.mapper.xm文件=====多条SQL可以使用延迟加载
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.xdf.dao.CountryDao"> <!--必须是对应的dao接口的全类名-->
<!-- 01. 根据省会的id 查询出 省会的信息-->
<select id="selectProvincialById" resultMap="provincialMap">
select pid,pname,countryid from provincial where pid=#{xxx}
</select>
<!-- 02. 根据省会的id 查询出 对应国家的信息
xxx就是resultmap中传递来的 countryid-->
<select id="selectCountryById" resultType="Country">
select cid,cname from country where cid=#{xxx}
</select> <!--对应的countryMap 这种方式 推荐使用 因为使用延迟加载-->
<resultMap id="provincialMap" type="Provincial">
<id property="pId" column="pid"/>
<result property="pName" column="pname"/>
<!-- Provincial有一个属性的类型是 Country 域属性
javaType:域属性对应的类型 -->
<association property="country" javaType="Country" select="selectCountryById"
column="countryid"/>
</resultMap> </mapper>
05.在MyBatis.xml文件中 管理Mapper文件
<!-- 加载映射文件信息 -->
<mappers>
<mapper resource="cn/bdqn/dao/ProvincialMapper.xml" />
</mappers>
06.测试类代码
public class CountryTest { CountryDao dao=null;
SqlSession session=null;
Logger log=Logger.getLogger(CountryTest.class); /**
* 在所有的test测试方法执行之前 都要执行的操作
*/
@Before
public void before(){
//获取session
session= SessionFactoryUtil.getSession();
dao=session.getMapper(CountryDao.class); //获取执行的类对象
} @After
public void after(){
if (session!=null){
session.close();
}
} /**
* 根据国家的编号 查询出 国家对应省会的信息
* 设置延迟加载
*01.在mybati核心配置文件中 增加setting节点
*02.节点中增加
* <setting name="lazyLoadingEnabled" value="true"/>
* <setting name="aggressiveLazyLoading" value="false"/>
*/
@Test
public void selectCountryLazy(){
Provincial provincial = dao.selectProvincialById(1);
//开启延迟加载的情况 直接输出省会的名称 执行1条sql log.debug(provincial.getpName());
log.debug(provincial.getCountry().getcName()); //执行2条 } }
MyBatis关联关系的更多相关文章
- mybatis关联关系映射
1.一对多关联关系 2.多对多关联关系 首先先用逆向生成工具生成t_hibernate_order.t_hibernate_order_item t_hibernate_book.t_hibernat ...
- mybatis 关联关系查询 java
<mapper namespace="com.rrz.modules.awardrecord.dao.CheckAwardsDao"> <resultMap ty ...
- mybatis之关联关系映射
Mybatis关联关系映射 1.一对多 首先先用逆向生成工具生成t_hibernate_order.t_hibernate_order_item 这两张表对应的model与mapper OrderVo ...
- JavaEE MyBatis
1. 简介 MyBatis本是apache的一个开源项目iBatis的升级版,2013年11月迁移到Github,是三层架构中持久层框架. 目前提供了Java..NET.以及Ruby三种语言实现的版 ...
- MyBatis学习笔记(二) 关联关系
首先给大家推荐几个网页: http://blog.csdn.net/isea533/article/category/2092001 没事看看 - MyBatis工具:www.mybatis.tk h ...
- myBatis 基础测试 表关联关系配置 集合 测试
myBatis 基础测试 表关联关系配置 集合 测试 测试myelipse项目源码 sql 下载 http://download.csdn.net/detail/liangrui1988/599388 ...
- mybatis学习笔记三(关联关系)
学习mybatis的关联关系,主要注解在代码上,这里不做解释.配置文件一样的就不贴了 1.关联关系表创建(学生对应老师 多对一) 学生老师表 2.表对应的实体类 package com.home.en ...
- MyBatis对象关联关系---- association与collection
Mybatis处理“一对多”的关系时,需要用到associasion元素.处理”多对一“用collection元素来实现(这两个元素在之前mapper文件中提到过). 本例子中,假设一名User可以有 ...
- Mybatis输入输出映射_动态sql_关联关系(一对一、一对多、多对多)
Mybatis输入输出映射_动态sql_关联关系(一对一.一对多.多对多)输入输出映射parameterType完成输入映射parameterType可以传入的参数有,基本数据类型(根据id查询用户的 ...
随机推荐
- 批量修改git仓库地址脚本
前言 公司的代码都存放在自己搭建的gitlab上面.之前由于老板升级gitlab.导致下面有个叫做"api"的groups无法访问.通过无所不能的谷歌才知道.在gitlab在某 ...
- springBoot之配置文件的读取以及过滤器和拦截器的使用
前言 在之前的学习springBoot中,成功的实现了Restful风格的基本服务.但是想将之前的工程作为一个项目来说,那些是仅仅不够的.可能还需要获取自定义的配置以及添加过滤器和拦截器.至于为什么将 ...
- C语言_scanf()和getchar() 使用[粗俗易懂]
原文地址:http://blog.csdn.net/hao5743/article/details/6939661/,以下是我重新整理的以下. 问题描述一:[分析scanf()和getchar()读取 ...
- Jquery就是这么简单
什么是Jquery? Jquey就是一款跨主流浏览器的JavaScript库,简化JavaScript对HTML操作 就是封装了JavaScript,能够简化我们写代码的一个JavaScript库 为 ...
- 2018-03-03-解决win下凭据删除不干净而无法登录共项目录的问题
layout: post title: 2018-03-03-解决win下凭据删除不干净而无法登录共项目录的问题 key: 20180303 tags: GIT 版本管理 modify_date: 2 ...
- 1.10 tuple 元组
元组(tuple)属于不可变序列 tuple特性: 特性一:可包含任意对象的有序集合 特性二:通过下标索引访问元素 特性三:固定长度,异质,可任意嵌套 特性四:不支持原位改变 特性五:存储机制:对象引 ...
- uva1347 经典dp
详细的思路书上面有,有一点要强调的是题意容易理解错:必须严格向右或则向左移动,不能到了第3个点又回到第2个点.否则这个状态方程是不成立的,变成了NP难问题 状态方程: dp[i][j]=min(dp[ ...
- 使用SpringSecurity保护你的Eureka.
因为注册中心基本上都是自己的应用在使用,应用不是特别多,可以写死,如果应用很多,那么就写入数据库把 pom <dependency> <groupId>org.springfr ...
- MFC使用SQLite 学习系列 二:无法容忍的数据插入效率
上一篇随笔中,介绍了,基本的使用没什么问题了,那么开始数据的插入. 一 问题--无法容忍的插入效率 代码写入基本完成,然后开始测试.起初,插入数据的时候基本上是插入每次插入9组数据,看不出来数据插入的 ...
- 2_成员函数(Member Functions)
成员函数以定从属于类,不能独立存在,这是它与普通函数的重要区别.所以我们在类定义体外定义成员函数的时候,必须在函数名之前冠以类名,如Date::isLeapYear().但如果在类定义体内定义成员函数 ...