锁定老帖子 主题:Hibernate Notes
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2007-09-27
private Set Attachments; ...... } public class Attachment{ private String id; private String name; ...... } 2)确认需要通过文档操作其类属性的值的。如 public class Category{ private Set Document; ...... }
public class Document{ private String id; private String name; } 需要进行如下操作的:
//取得分类 Category category=getHibernateTemplate().get(Category.class,0); Set documents=category.getDocuments(); Documents document=(Document)documents.iterator().next(); document.setName(“Jimmy”); //保存 getHibernateTemplate().update(category); 即为需要通过分类操作文档的属性值,可以根据需要设置cascade属性,一般不推荐进行这种操作。
2.对于特定类型的类映射的说明 char 类型映射到数据库中为char(1)类型,但是会在取值时出现 exception setting property with CGLIB异常 int 类型经过Hiberante的映射成int类型后,在数据库中会有默认值0,如果手动对数据库中的数据进行操作,一定要加上值0,否则会在取值的时候产生 exception setting property with CGLIB异常
3.关于延迟加载的使用 对于是否使用延迟加载,应当引起注意。 从性能上考虑,应当完全使用延迟加载,这也是从Hibernate3之后,hibernate开发小组,将延迟加载的机制从原来的不使用延迟加载改为延迟加载的原因。 从使用JDBC操作来看,对于所有的对象都是使用的延迟加载的,因为只是从数据库中取出了自己需要的数据。而从面向对象的角度来说,似乎拿到一个对象,理所当然应当是得到其属性的值,不管其为本身是一个对象还是单一的属性。而事实上,在实际操作中,应当鼓励使用延迟加载,除非是迫不得已的情况下,我们才使用不延迟加载。 事实证明,不使用延迟加载对于性能的影响是巨大的,尤其是其中的属性是集合时,最可怕的就是,其属性的类中,还是未使用的延迟加载,这有点类似于多米诺骨牌,一连串的取出来。 但是使用延迟加载又会存在一个问题,尤其是取集合的时候,会有这样的问题,比如说我们在拿到文档的时候,同进肯定要拿到附件,而我们使用了如下的HQL语句: From Document where type='k' 这种查出来的,仅仅只是文档,不会拿到附件(但是事实上,根据hibernate)的延迟机制,拿到的是附件的id,当然,我们可以再根据id一个一个去拿一次,但是这种方法是不可取的,因为这违背了面向对象设计的原则。但是事实上,我们只可以居中去选择。 如果我们属性是完全依赖于对象的,那么,我们可以不要使用延迟加载,若不是完全依赖的话,如category与document的关系,我们应当使用延迟加载。
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
浏览 1830 次