快速业务通道

Hibernate从2升级到3不支持Oracle8外连接(+)的解决办法 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-15
teQueryStrings[i], enabledFilters,   factory);}((FilterTranslator) translators[i]).compile(collectionRole, factory.getSettings() .getQuerySubstitutions(), shallow);}

Hibernate从2升级到3不支持Oracle8外连接(+)的解决办法(5)

时间:2011-08-31

改完之后,把编译后的HQLQueryPlan.class覆盖到hibernate3.jar包中相应的目录中即可,或者把这个类放在classes下相应的目录中,在WEB应用程序中 WEB-INF/classes中的类是优先于jar包中的类先加载。

以上做法两种有些矛盾的问题也就得到解决了,org.hibernate.Session既可以执行Hibernate3 引入的 delete/update语句,还能够在 Oracle/Sybase中用(+)外连接方式而不需要配置X对X的连接关系。

下面再介绍一种折中的解决办法,不知大家注意到没有,在Hibernate3中的

org.hibernate.SessionFactory的openSession方法返回的是一个

org.hibernate.classic.Session对象,而org.hibernate.classic.Session是继承自org.hibernate.Session的。

public org.hibernate.classic.Session openSession(Connection connection);

public interface Session extends org.hibernate.Session

而通常我们顺应新潮流,是用org.hibernate.Session去引用SessionFactory的方法openSession()的返回值的,于是我们想用 session.delete(sql) 方法时,就把返回的Session实例转型为 org.hibernate.classic.Session即可。

((org.hibernate.classic.Session)session).delete("from User u where u.name=''Unmi''");

如果你也想用原始Session的其他已被摈弃的方法,亦可如此这般做。

当然了,在另一方面要让Hibernate 能支持 Oracle/Sybase中用(+)外连接方式, 您还是要使

用传统的语法分析器,他将不能理解新的delete/update语句,很遗憾。

所以为了顺应新的潮流的发展,应使用第一种方法。要知道hibernate3中的delete/update语句可比2中的session.delete(hql)方法效率高,hibernate3中直接向数据库发一个delete语句,而在hibernate2中的delete(hql)方法是需要首先加载对象在删除,确有些多次一举,不过又是也有它的道理,update也类此。

在补充一个:hibernate会对 hql 对应的 HQLQueryPlan 进行缓冲的,在类 QueryPlanCache 中处理

HQLQueryPlanKey key = new HQLQueryPlanKey( queryString, shallow, enabledFilters );HQLQueryPlan plan = ( HQLQueryPlan ) planCache.get ( key );if ( plan == null ){ ..................}HQLQueryPlanKey key = new HQLQueryPlanKey( queryString, shallow, enabledFilters );HQLQueryPlan plan = ( HQLQueryPlan ) planCache.get ( key );if ( plan == null ){ ..................} 

依据queryString(hql)生成key值.

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号