(Mybatis笔记)多表关联实体与标签对应关系分析

        ORM (object Relational Mapping):对象关系映射MyBatis框架是ORM非常优秀的框架,java语言中以对象的方式操作数据,存到数据库中是以表的方式进行存储,对象中的成员变量与表中的列之间的数据互换称为映射。整个这套操作就是ORM。

***以下分析不代表全部,使用什么连接方式,取决于业务需求和实体之间的关系(仅供参考)***

(1)一对一:添加对方的对象(A实体有B对象 + B实体有A对象),使用<resuletMap>和<association>标签联合包裹映射数据。

        定义SQL:“A为主表,B为副表”或者“B为主表,A为副表”时,均使用内连接关联,不会影响查询数据的丢失。主表紧接from后面。
(2)一对多:一方实体添加多方实体的List对象集合,一方实体采用<resuletMap>标签包裹映射数据,多方实体采用<collection>标签包裹映射数据。

        定义SQL:“一方为主表,多方为副表”,使用左连接。例如“from 一方 left join 多方 on 条件 ”,可以避免因副表没有主表数据而导致查询结果丢失掉主表的数据。(举反例:如果使用内连接,副表没有主标数据,select的并集信息就是null值,集合就为null【不包含主表数据】)主表紧接from后面。
(3)多对一:多方实体添加一方实体的对象,多方实体采用<resuletMap>标签包裹映射数据,一方实体采用<association>标签包裹映射数据。

        定义SQL:“多方为主表,一方为副表”,使用内连接,例如“from 多方 inner join 一方 on 条件 ”,副表有数据,那么与它对应的主表必然有数据,就会查询并集数据,返回封装有数据集合。主表紧接from后面。
(4)多对多多方A实体添加多方B实体的List对象集合,多方A采用<resuletMap>标签包裹映射数据,多方B采用<collection>标签包裹映射数据。

       定义SQL:“多方A为主表,多方B为副表”,使用左连接,例如“ from 多方A left join 多方B on 条件 ”。“多方B为主表,多方A为副表”,使用左连接,例如“from 多方B left join 多方A on 条件 ”。主表紧接from后面。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

电竞丶小松哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值