1、级联属性的方式封装查出1-1

查钥匙的时候顺别把对应的级联的那把锁也查出来

1)、两个JavaBean,Key里有对应的Lock(private Lock lock;//当前钥匙能开哪个锁;)

2)、建两张表key表和lock表,key表里加外键

外键好处,安全性:单纯删key表里的一行记录删不掉,只有删除key表记录才行

3)、sql语句要对两个表两个相同名字id起别名,

id  keyname  lockid  “lid”  lockname

-        -               -         -        -

方便resultMap自定义封装规则指定返回数据的对应数据库列名

4)resultMap引用

2. association标签,mybatis推荐方便(续1)

表示联合了一个对象

<association property="lock" javaType="com.atguigu.bean.Lock">

<!-- 定义lock属性对应的这个Lock对象如何封装 -->

<id property="id" column="lid"/>

<result property="lockName" column="lockName"/>

</association>

【打印】

Key keyById = mapper.getKeyById(2);

System.out.println(keyById);

Key [id=2, keyName=2号钥匙, lock=Lock [id=2, lockName=2号锁]]

3. collection标签(一个门人手一把钥匙)1-n

一个Lock对应一个Key集合(collection自动整成list)

1)、JavaBean Lock  private List<Key> keys;)

<!--

private Integer id;

private String lockName;

//查询锁子的时候把所有的钥匙也查出来

private List<Key> keys;

id  lockName                  kid  keyname     lockid

3  303办公室的锁子               3  303钥匙1           3

3  303办公室的锁子               4  303钥匙2           3

3  303办公室的锁子               5  303钥匙3           3

-->

<resultMap type="com.atguigu.bean.Lock" id="mylock">

<id property="id" column="id"/>

<result property="lockName" column="lockName"/>

<!--

collection:定义集合元素的封装

property="":指定哪个属性是集合属性

javaType:指定对象类型;association

ofType="":指定集合里面元素的类型

-->

<collection property="keys" ofType="com.atguigu.bean.Key">

<!-- 标签体中指定集合中这个元素的封装规则 -->

<id property="id" column="kid"/>

<result property="keyName" column="keyname"/>

</collection>

</resultMap>

【打印】

与1-1不同的是取出对象后,对其内部list遍历才能得到collection

Lock lock = mapper.getLockById(3);

System.out.println(lock);

System.out.println("所有锁子如下:");

List<Key> keys = lock.getKeys();

for (Key key : keys) {

System.out.println(key);

}

Lock [id=3, lockName=303办公室的锁子]

所有锁子如下:

Key [id=3, keyName=303钥匙1]

Key [id=4, keyName=303钥匙2]

Key [id=5, keyName=303钥匙3]

【串线篇】SQL映射文件-联合查询(完结association+cellection)的更多相关文章

  1. 【串线篇】sql映射文件-分布查询(上)association 1-1

    1.场景 1把钥匙带1把锁 JavaBean:private Lock lock;//当前钥匙能开哪个锁: 1). interface KeyDao: public Key getKeyByIdSim ...

  2. 【串线篇】sql映射文件-分布查询(下)cellection的1-n

    1.场景 一个门人手一把钥匙 1-n 一个Lock对应一个Key集合(collection自动整成list) Map不是collection的子接口或者实现类.Map是一个接口. JavaBean:p ...

  3. 关于mybatis中sql映射文件模糊查询的使用

    1.从前台传递一个String类型的参数到后台进行查询,如果牵涉到模糊查询会报错,应该把参数封装到对象中再进行传递然后进行模糊查询 2.一个查询框,多个查询条件 <if test="c ...

  4. NHibernate 映射基础(第三篇) 简单映射、联合主键

    NHibernate 映射基础(第三篇) 简单映射.联合主键 NHibernate完全靠配置文件获取其所需的一切信息,其中映射文件,是其获取数据库与C#程序关系的所有信息来源. 一.简单映射 下面先来 ...

  5. Mybatis sql映射文件浅析 Mybatis简介(三)

    简介 除了配置相关之外,另一个核心就是SQL映射,MyBatis 的真正强大也在于它的映射语句. Mybatis创建了一套规则以XML为载体映射SQL 之前提到过,各项配置信息将Mybatis应用的整 ...

  6. Mybatis sql映射文件浅析 Mybatis简介(三) 简介

    Mybatis sql映射文件浅析 Mybatis简介(三)   简介 除了配置相关之外,另一个核心就是SQL映射,MyBatis 的真正强大也在于它的映射语句. Mybatis创建了一套规则以XML ...

  7. SQL映射文件-----MySQL关系映射【1对1,1对多,多对多】

    SSM框架下,mapper.xml 中 association 标签和 collection 标签的使用 当数据库中表与表之间有关联时,在对数据库进行操作时,就不只是针对某一张表了,需要联表查询 My ...

  8. SQL映射文件

     SQL映射文件的几个顶级元素 mapper - namespace cache - 配置给定命名空间的缓存 cache-ref – 从其他命名空间引用缓存配置 resultMap –用来描述数据库结 ...

  9. MyBatis 的基本要素—SQL 映射文件

    MyBatis 真正的强大在于映射语句,相对于它强大的功能,SQL 映射文件的配置却是相当简单.对比 SQL 映射配置和 JDBC 代码,发现使用 SQL 映射文件配置可减少 50% 以上的代码,并且 ...

随机推荐

  1. NotSerializableException

    这个错误是实体类没有  继承  Serializeble.

  2. C#在WinForm开发中Label换行方法

    很多朋友都会在开发WinForm中遇到Label要显示的内容太长,但却不能换行的问题.这里我总结了几种方法,供大家参考. 第一种是把Label的AutoSize属性设为False,手动修改Label的 ...

  3. Oracle dmp文件(表)导入与导出

    dmp文件是作为oracle导入和导出表使用的文件格式dmp文件导出dmp文件导出用的比较多的一般是三种,他们分别是:1.导出整个数据库实例下的所有数据2.导出指定用户的所有表3.导出指定表. 打开命 ...

  4. 攻防世界 | when_did_you_born

    所以题目要求是输入生日1926 payload: from pwn import * io = remote("111.198.29.45",40803) io.recvline( ...

  5. LintCode之两两交换链表中的节点

    题目描述: 我的思路: 由题目描述可知,题目是要求将第一个与第二个节点,第三个与第四节点....进行交换,而进行交换时只用将节点的值进行交换即可.需要注意的是:当链表为null或者当链表只有一个节点时 ...

  6. P1063能量项链

    传送 这又是一道经典的区间DP题. 复习一下区间DP的做法. 三重循环,第一层枚举区间长度,第二层枚举起点,第三层枚举断点. 区间长度是从1到n-1(因为如果是从1到n的话,1+n≠n,所以是1到n- ...

  7. 【CDN+】 一些常用的Linux命令,crontab+VI+Hive(持续更新)

    前言 本文主要是记录下工作中可能用到的一些linux指令,当作字典查用 Crontab 基本命令 # 安装 yum -y install vixie-cron crontabs#查看状态 servic ...

  8. JS - 迭代协议

    Iteration protocols | MDN 可迭代协议(iterable protocol) 迭代器协议(iterator protocol)

  9. DR 项目小结

    前言 个人的项目总结, 非技术类博文. 需要补充的知识点 HTTP 协议与其内置方法 curl 指令和各选项的意义 Keystone 认证流程和各项目配置文件 [keystone_authtoken] ...

  10. Selenium WebDriver UI对象库

    UI对象库:使用配置文件存储测试页面上的定位和定位表达式,做到定位数据和程序的分离. 第一步:实现工具类Object工具类,供测试程序调用. /** * 使用配置文件存储测试页面上的定位和定位表达式, ...