多对一:
load,get的区别:
之对于get和load的根本区别,一句话,hibernate对于load方法认为该数据在数据库中一定存在,
可以放心的使用代理来延迟加载,如果在使用过程中发现了问题,只能抛异常;
而对于get方法,hibernate一定要获取到真实的数据,否则返回null。
1)当记录不存在时候,get方法返回null,load方法产生异常
2)load方法可以返回实体的代理类,get方法则返回真是的实体类
3)load方法可以充分利用hibernate的内部缓存和二级缓存中的现有数据,而get方法仅仅在内部缓存中进行数据查找,
如果没有发现数据則将越过二级缓存,直接调用SQL查询数据库。
4) 也许别人把数据库中的数据修改了,load如何在缓存中找到了数据,则不会再访问数据库,而get则会返回最新数据。
find,iterator的区别:
(1) iterator首先会获取符合条件的记录的id,再跟据id在本地缓存中查找数据,查找不到的再在数据库中查找,结果再存在缓存中。N+1条SQL。
(2)find跟据生成的sql语句,直接访问数据库,查到的数据存在缓存中,一条sql。
一对一:
Person -- Card
在Card中引用外键作为其主键
<id name="id">
<id name="id">
<generator class="foreign">
<param name="property"></param>
</generator>
</id>
</id>
//加上约束
<one-to-one name="person" constrained="true"/>
多对多:
效率很低,如查一条记录,要到三张表里去查
多对一较为常用
分享到:
评论