- 把关联保存为一个表,存储关联表的外键
- 在对象中,使用集合作为域值,来处理多值域.
- 而在DB中,只能有单值域.
- 外键映射的核心,是在关联关系的单值端使用外键来维持联系.
- 而在多对多的关联关系中,已经不存在单值端了.
- 运行机制
- 使用一个链接表来保存关联关系.
- 仅有两个字段,即两个关联表的外键ID.
- 对于每一对相关联的对象,它会有一个数据行与之对应.
- 链接表没有对应的内存对象.所以也就没有ID.其主键是两个关联表的主键的组合.
- 从链接表中加载Data需要两次查询,例如为雇员加载机能的问题
- 1,查询EmployeesSkills表,得出该雇员关联的所有行.
- 2,根据这些关联行的ID,查找出所有的机能对象.
- 当内存中已存在这些信息时,没有问题.否则需要多次的DB查询开销.
- 从链接表中加载Data需要两次查询,例如为雇员加载机能的问题
- 使用时机
- 标准情况是多对多的关联关系.
- 当相关联的表结构已经无法改变时,只能使用它.
- 有时,关联表也会存储某种关系的信息,此时,它就会对应一个真实的领域对象.
相关文章
- 03-21关联表映射 Association Table Mapping
- 03-21phoenix关联hbase表:通过建立视图映射或表映射的方式
- 03-21phoenix关联hbase表:通过建立视图映射或表映射的方式
- 03-21源数据与目标数据的映射(2张无关联的表联查)
- 03-21关联表映射 Association Table Mapping
- 03-21PHP关联数组和哈希表(hash table) 未指定
- 03-21PHP关联数组与哈希表(hash table) 不指定
- 03-21在MyBatis中查询数据、涉及多参数的数据访问操作、插入数据时获取数据自增长的id、关联表查询操作、动态SQL、关于配置MyBatis映射没有代码提示的解决方案
- 03-21eclipse + JBoss 5 + EJB3开发指南(10):通过继承实体Bean,将单个表映射成多个表(单表策略,SINGLE_TABLE)
- 03-21hibernate5(14)注解映射[6]多对多中间表关联