Hibernate Notes
-
在进行级联操作的设计时,在一般情况下,不应当使用级联。在以下情况下可以使用级联。
1)类属性完全依赖于类。如:
public class Document{
//附件完全依赖于文档,即文档删除后附件不再存在
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的关系,我们应当使用延迟加载。
发表评论
提醒: 该博客已发表在公共论坛,博客所有留言会成为论坛回贴,留言请注意遵守论坛发贴规则
- 浏览: 69352 次
- 性别:

- 来自: 北京

- 详细资料
搜索本博客
最近加入圈子
最新评论
-
一天一夜,终于把页面布局 ...
美工一向是我的弱项哈。
-- by xiaopao -
市场至上,还是我们应当坚 ...
jimmy.shine 写道 A-->B-->C-->A 原因在这里
-- by cyberblue -
市场至上,还是我们应当坚 ...
市场和原则,有矛盾的时候,还是坚持原则吧
-- by hyhongyong -
市场至上,还是我们应当坚 ...
这事不怪楼主,怪技术总监和项目经理的沟通不够,双方都无法总结出一套Pattern ...
-- by cyberblue -
市场至上,还是我们应当坚 ...
市场是老大,这是毫无疑问的,但是请仔细思考自己到底是处于哪个市场里。明明在劳动力 ...
-- by tj19832






评论排行榜