Hibernate 2与Hibernate 3的区别

这篇文件整理了一些我改写Hibernate笔记时,从Hibernate 2到Hibernate 3中所遇过的不同点,如果发现有其它重要的改变,将随进新增至这个文件中。
对 DTD 文件的引用

hibernate.cfg.xml中对DTD文件的引用必须改变,在Hibernate 2中是这样:
...

<!DOCTYPE hibernate-configuration

    PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"

    "http://hibernate.sourceforge.net/hibernate-configuration-2.0.dtd">

...

在Hibernate 3中必须这样设置:
...

<!DOCTYPE hibernate-configuration PUBLIC

    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"

    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

...


映射文件在Hibernate 2时是这样:
...

<!DOCTYPE hibernate-mapping

    PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN"

    "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">

...

在Hibernate 3中是这样:
...

<!DOCTYPE hibernate-mapping

    PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"

    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

...

package 的改变
Hibernate 2中API的顶层package名称是net.sf.hibernate,在Hibernate 3中是org.hibernate,例如Hibernate 2中的net.sf.hibernate.SessionFactory在Hibernate 3中改为org.hibernate.SessionFactory。

取消 Session 中 find()、iterate() 方法

Session中的 find()方法被取消了,必须使用Session的createQuery()建立Query实例,并使用list()方法来取代。Session的 iterate()被取消了,由Query介面上的iterator()来取代,详细请看 Query.list()、iterator()

HQL 新增语句

新增 update 语句
Query query = session.createQuery("update User set age=30 where id=1");

query.executeUpdate();

新增 delete 语句
Query query = session.createQuery("delete User where age<20");

query.executeUpdate();
自定义 insert、update、delete

Hibernate 3的映射文件中新增了<sql-insert>、<sql-update>与<sql-delete>三个标签,您可以在这三个标签中使用SQL自定义您的INSERT、UPDATE、DELETE,也就是储存、更新、刪除资料时的行為,详细请看 自定义 insert、update、delete
其它
  • Expression类別仍可使用,但新增Restrictions类別作为Expression类別的替代。
  • 新增 DetchedCriteria
  • 新增 动态模型(Dynamic Model)
  • HibernateException 变为Checked exception。
  • Interceptor 新增了几个方法。
  • Lazy Initialization预设为 true,不想使用的话,必须在映射文件中设定lazy属性为false。
  • 可透过org.hibernate.tool.instrument.InstrumentTask对.class档进行buildtime bytecode instrumentation,实现属性的Lazy Initialization。  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值