Hibernate基础全面介绍
在向大家详细介绍Hibernate之前 首先让大家了解下Hibernate基础 然后全面介绍get和load有两个重要区别
Hibernate基础之关联
◆单向关联 单向关联没有inverse用法
◆双向关联 使用inverse来指定 inverse=false(默认值)表示自己是关联的拥有者 Inverse=true表示另一端是关联的拥有者
如何管理双向关联?
必须显示地管理关联的两端对一端进行了修改 两端都要重新设置 要保持同步 如何决定关联的拥有者(一般来说 拥有外键的一端就是关联的拥有者?????)
◆一对一 任何一端都可以作为关联的拥有者 但是应该选择其中之一(而且只 能选择一个) 如果没有指定拥有者 就会导致循环依赖
◆一对多 多 端必须作为关联的拥有者 (一般都是多端拥有外键???)
◆多对一 多 端必须作为关联的拥有者 (一般都是多端拥有外键???)
◆多对多 任何一端都可以作为关联的拥有者
Hibernate基础之saveOrupdate()使用
保存已经持久化的对象是不合适的 同样 更新瞬时对象也不合适的 如果从应用程序代码判断对象的状态是不可能的 或者不方便 那么可以使用saveOrUpdate()方法
Hibernate基础之load()与get()
public Object load(Class theClass Serializable id) throws HibernateException
public Object load(String entityName Serializable id) throws HibernateException
public Object get(Class clazz Serializable id) throws HibernateException
public Object get(String entityName Serializable id )thtows HibernateException
Hibernate中get方法和load方法的根本区别在于
对于get方法 Hibernate会确认一下该id对应的数据是否存在 首先在session缓存中查找 然后在二级缓存中查找 还没有就查询数据库 数据库中没有就返回null
load方法加载实体对象的时候 根据映射文件上class级别的lazy属性的配置(默认为true) 分情况讨论
◆若为true 则首先在Session缓存中查找 看看该id对应的对象是否存在 不存在则使用延迟加载 返回实体的代理类对象(该代理类为实体类的子类 由CGLIB动态生成) 等到具体使用该对象的时候 再查询二级缓存和数据库 若仍没发现符合条件的记录 则会抛出一个ObjectNotFoundException
◆若为false 就跟get方法查找顺序一样 只是最终若没发现符合条件的记录 则会抛出一个ObjectNotFoundException
这里get和load有两个重要区别
如果未能发现符合条件的记录 get方法返回null 而load方法会抛出一个ObjectNotFoundException load方法可返回没有加载实体数据的代理类实例 而get方法永远返回有实体数据的对象 (对于load和get方法返回类型 好多书中都说 get方法永远只返回实体类 实际上并不正确 get方法如果在session缓存中找到了该id对应的对象 如果刚好该对象前面是被代理过的 如被load方法使用过 或者被其他关联对象延迟加载过 那么返回的还是原先的代理对象 而不是实体类对象 如果该代理对象还没有加载实体数据(就是id以外的其他属性数据) 那么它会查询二级缓存或者数据库来加载数据 但是返回的还是代理对象 只不过已经加载了实体数据 )
Hibernate基础之刷新实体
Hibernate提供了一种用数据库表刷新(refresh)持久对象的机制 使用Session接口的refresh()方法的其中之一刷新持久对象的实例
lishixinzhi/Article/program/Java/ky/201311/28031