- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
解决Hibernate SQL Query Cache的一个可靠性问题(附源码) 上篇 帖子 Hibernate查询缓存的一个可靠性问题 说发现Hibernate 的 Query Cache 在使用 SQL Query 时的一个可靠性 Bug, 即在关联表数据修改后,无法查询出最新数据的问题。 经过源码分析,找到问题所在,并通过修改 Hibernate 源代码,成功解决了此问题。 ??? Hibernate 3.1, JDK 1.4 1. 问题原因: ??? 走了一下源码,大致找到了问题所在,? SQLQueryReturnProcessor 在分析 query 时,用于判断缓存失效的? querySpaces[]只分析出了返回结果对应的表,例如例子中的权限点表:sys_perm,? 而sql中的关联表没有分析出来,并放到 querySpaces[] 中。 ?? 具体分析: ??? 类 org.hibernate.loader.custom.SQLCustomQuery, 它是解析 SQL Query 的一个包装类。 ??? SQLCustomQuery 类有一个与缓存相关的属性,querySpaces 集合 : ??
Java代码
private?final?Set?querySpaces?=?new?HashSet();???
private final Set querySpaces = new HashSet();
??? 通过源码分析,发现 querySpaces? 主要用来进行Cache更新检查,querySpaces? 存放的是基本VOClass 对应的 tableName, 例如: {SYS_PERM,SYS_USER} . Hibernate 在执行查询时,会检查这个集合中的所有 tableName, 如果该任意一个 tableName 对应 VOClass 二级缓存 有增,删,改的更新操作,即 UpdateTimestampsCache 不是最新的 ,那么该 Query 的 cache 就失效,就会重新去数据库中查询 ID 集合。 ??? SQLCustomQuery 在构造函数中即进行 sql 的解析和querySpaces[]的判断,其中中有这样一段代码:
Java代码
??public?SQLCustomQuery(.....)?throws?HibernateException?{ ??
????SQLQueryReturnProcessor?processor?=?new?SQLQueryReturnProcessor(queryReturns,?scalarQueryReturns,?factory); ??
???cess(); ??
?????.... ??
????SQLLoadable[]?entityPersisters?=?(SQLLoadable[])?processor.getPersisters().toArray(?new?SQLLoadable[0]?); ??
?????.... ??
???for?(int?i?=?0;?i??entityPersisters.length;?i++)?{ ??
??????SQLLoadable?persister?=?entityPersisters[i]; ??
???//alias2Persister.put(?aliases[i],?persister?); ??
??//TODO:Does?not?consider?any?other?tables?referenced?in?the?query???? ??
ArrayHelper.addAll(?querySpaces,?persister.getQuerySpaces()?); ??
????.... ??
???} ??
....??
public SQLCustomQuery(.....) throws HibernateException {
SQLQueryReturnProcessor processor = new SQLQueryReturnProcessor(queryReturns, scalarQueryReturns, factory);
cess();
....
SQLLoadable[] entityPersisters = (SQLLoadable[]) processor.getPersisters().toArray( new SQLLoadable[0] );
....
for (int i = 0; i entityPersisters.le
文档评论(0)