解决Hibernate SQL Query Cache的一个可靠性问题.docVIP

  • 4
  • 0
  • 约6.76千字
  • 约 6页
  • 2020-07-17 发布于湖北
  • 举报

解决Hibernate SQL Query Cache的一个可靠性问题.doc

解决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();??? ??? 通

文档评论(0)

1亿VIP精品文档

相关文档