在向大家详细介绍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方法的根本区别在于:
1.对于get方法,Hibernate会确认一下该id对应的数据是否存在,首先在session缓存中查找,然后在二级缓存中查找,还没有就查询数据库,数据库中没有就返回null。
2.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()方法的其中之一刷新持久对象的实例.
- Public void refresh(Object object) throws HibernateException
【编辑推荐】