`
csbison
  • 浏览: 149950 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

Hibernate's FAQ

阅读更多

1. 关于session
   
 1) 什么时机对session进行打开和关闭?
    首先,别用session-per-operation这种反模式了,也就是说,在单个线程中, 不要因为一次简单的数据库调
用,就打开和关闭一次Session!数据库事务也是如此。
    最好的模式是:
    ①session-per-request模式,所有载入的实例在用户思考的过程 中都处于与Session脱离的状态。
    ②session-per-conversation模式,当一个新的客户端请求到来的时候,它又重新连接上底层的JDBC连接。

   2) 关于session要注意的问题。
    Session 缓存了处于持久化状态的每个对象(Hibernate会监视和检查脏数据)。 这意味着,如果你让Session打开很长一段时间,或是仅仅载入了过多的数据, Session占用的内存会一直增长,直到抛出OutOfMemoryException异常。
    当异常发生的时候,必须要回滚 Transaction ,关闭Session。如果你不这样做的话,Hibernate无法保证内存状态精确的反应持久状态。

   2. 关于映射关联
    对映射关联要注意的问题:
    实际上,我们认为绝大多数的连接是一对多和多对一的,你应该谨慎使用其它连接风格,用之前问自己一句,是否真的必须这么做。单向关联更加难于查询。在大型应用中,几乎所有的关联必须在查询中可以双向导航。
    对于关联表不要设置级联删除,而是设置级联的约束或者no action,让应用去手动删除.

   3. 关于自动化生成工具
    对映射文件、数据库以及实体的自动化生成,无论采用什么工具和顺序都有不完全一致的问题,所以都需要根据你的设计进行修改。
    
   
   4. 关于实体类的增强
    事实上,几乎所有的OR/Mapping框架都需要对实体类进行增强,以便持久化框架能跟踪实体的变化。Hibernate采用的是CGLIB在运行期增强实体的方式,因此无需手动增强这一步骤。而大多数JDO框架需要进行手动增强。


   6. 关于业务系统的分层
    一般的业务系统是按照以下的模式来开发:
    1) 实体层(entity)。考虑到实体层一般跟数据库层进行映射,所以实体的属性最好跟DB的表字段对应,最好是小写。

    2) DAO层(persistence)。对实体进行持久化(例如读写数据库)的最小单元操作,即该层是针对实体的操作而不针对业务操作。不进行事务管理或者ORM工具的Session管理。这一层相对简单。
    3) Serivice层(service)。对每个业务用例实现对应的方法,每个方法体进行事务或者ORM工具的Session管理。供MVC的控制层调用。

    4) MVC的控制层(control)。可以是java之Servlet、struts之action、.net之codebehind代码,也可以是桌面UI的处理层。

    5) MVC的显示层(view)。这是对美工提供的页面代码进行最小化改动,可以是jsp、aspx、velocity的模板文件。

    对于简单的应用,第2和第3层可以合并。

   7. 主键生成策略
    increment:生成long, short或者int类型的主键,不能在cluster环境下使用。适用于所有数据库   
    
identity:生成long, short或者int类型的主键。适用于DB2, MySQL, MS SQL Server, Sybase and HypersonicSQL 
    sequence :生成long, short或者int类型的主键。适用于DB2, PostgreSQL, Oracle, SAP DB, McKoi,Interbase. 
    hilo:生成long, short或者int类型的主键。需要提供一个数据库的表来存放生成的主键信息。当采用应用服务器的JTA提供的数据库连接或者用户自定义的数据库连接的时候,不要使用这种主键生成方式。适用于所有数据库 
    seqhilo:采用给定的数据库的sequence来生成long, short或者int类型的主键。适用于DB2, PostgreSQL, Oracle, SAP DB, McKoi,Interbase. 

    uuid.hex采用128位的算法来生成一个32位字符串。最通用的一种方式。适用于所有数据库 
    uuid.string:同样采用128位的UUID算法。将生成的字符编码位16位。适用于除PostgreSQL.以外的数据库 
    native:根据具体连接的数据库从identity, sequence或者hilo选择一种来生成主键。适用的数据库根据选择的生成方式确定。 
    assigned: 交给应用自己给主键赋值。要注意的是赋值必须在调用save()方法之前完成。适用的数据库根据选择的生成方式确定。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics