[hibernate-issues] [Hibernate-JIRA] Commented: (HHH-4838) 2L-Querycache ImmutableNaturalKeyLookup not properly recognized as hasImmutableNaturalId() is called on wrong EntityMetamodel

Gail Badner (JIRA) noreply at atlassian.com
Mon Oct 3 18:13:23 EDT 2011


    [ http://opensource.atlassian.com/projects/hibernate/browse/HHH-4838?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=43946#comment-43946 ] 

Gail Badner commented on HHH-4838:
----------------------------------

I've committed the fix to master and 3.6.

I forgot to prefix the master commit message with "HHH-4838". See commit b307a801a748eed42810e10d7e413f185953fe43 for details: https://github.com/hibernate/hibernate-core/commit/b307a801a748eed42810e10d7e413f185953fe43

This fixes looking up an entity by an immutable natural ID from the query cache when that entity has non-lazy associations.

The lookup by natural ID optimization is not used for a Criteria if it has projections, subcriteria, or any restrictions (other than Restrictions.naturalId()).  

> 2L-Querycache ImmutableNaturalKeyLookup not properly recognized as hasImmutableNaturalId() is called on wrong EntityMetamodel
> -----------------------------------------------------------------------------------------------------------------------------
>
>                 Key: HHH-4838
>                 URL: http://opensource.atlassian.com/projects/hibernate/browse/HHH-4838
>             Project: Hibernate Core
>          Issue Type: Bug
>          Components: caching (L2)
>    Affects Versions: 3.5.0-Beta-3
>         Environment: 3.5.0-Beta3, HSQLDB, EHCache as 2L cache implementation
>            Reporter: Guenther Demetz
>            Assignee: Gail Badner
>             Fix For: 3.6.8, 4.0.0.next
>
>         Attachments: TestImmutableNaturalId.jar, TestImmutableNaturalKeyLookup.jar
>
>
> If a entityclass with immutable naturalId has non-lazy properties (for instance a OneToOne association),
> then more entityPersisters are involved in the query as it becomes a join-query eager loading the associated entity.
> The method Loader#getResultFromQueryCache presumes that the first entityPersister in the array is the main entity class.
> boolean isImmutableNaturalKeyLookup = queryParameters.isNaturalKeyLookup()
> 					&& getEntityPersisters()[0].getEntityMetamodel().hasImmutableNaturalId();
> Debugging attached testcase you can see indeed that getEntityPersisters()[0] returns SingleTableEntityPersister(hello.D)
> which is the persister of the associated entity, not the main one!
> Consequently the query is not considered as isImmutableNaturalKeyLookup, despite fullfilling all conditions.
> Here my output (with enabled p6spy):
> 11:53:15,651  INFO Version:37 - Hibernate Annotations 3.5.0.Beta1
> 11:53:15,690  INFO Environment:563 - Hibernate 3.5.0-Beta-3
> 11:53:15,694  INFO Environment:596 - hibernate.properties not found
> 11:53:15,700  INFO Environment:774 - Bytecode provider name : javassist
> 11:53:15,706  INFO Environment:655 - using JDK 1.4 java.sql.Timestamp handling
> 11:53:15,863  INFO Version:38 - Hibernate EntityManager 3.5.0.Beta1
> 11:53:16,356  INFO AnnotationBinder:446 - Binding entity from annotated class: hello.A
> 11:53:16,424  INFO EntityBinder:471 - Bind entity hello.A on table A
> 11:53:16,526  INFO AnnotationBinder:446 - Binding entity from annotated class: hello.D
> 11:53:16,527  INFO EntityBinder:471 - Bind entity hello.D on table D
> 11:53:16,686  WARN Ejb3Configuration:943 - hibernate.connection.autocommit = false break the EJB3 specification
> 11:53:16,702  INFO HibernateSearchEventListenerRegister:75 - Unable to find org.hibernate.search.event.FullTextIndexEventListener on the classpath. Hibernate Search is not enabled.
> 11:53:16,718  INFO DriverManagerConnectionProvider:64 - Using Hibernate built-in connection pool (not for production use!)
> 11:53:16,719  INFO DriverManagerConnectionProvider:65 - Hibernate connection pool size: 20
> 11:53:16,720  INFO DriverManagerConnectionProvider:68 - autocommit mode: false
> 11:53:16,921  INFO DriverManagerConnectionProvider:103 - using driver: com.p6spy.engine.spy.P6SpyDriver at URL: jdbc:hsqldb:hsql://localhost
> 11:53:16,922  INFO DriverManagerConnectionProvider:109 - connection properties: {user=sa, password=****, autocommit=false, release_mode=after_transaction}
> 11:53:17,002  INFO SettingsFactory:117 - RDBMS: HSQL Database Engine, version: 1.8.0
> 11:53:17,004  INFO SettingsFactory:118 - JDBC driver: HSQL Database Engine Driver, version: 1.8.0
> 11:53:17,068  INFO Dialect:223 - Using dialect: org.hibernate.dialect.HSQLDialect
> 11:53:17,082  INFO JdbcSupportLoader:79 - Disabling contextual LOB creation as JDBC driver reported JDBC version [3] less than 4
> 11:53:17,085  INFO TransactionFactoryFactory:62 - Transaction strategy: org.hibernate.transaction.JDBCTransactionFactory
> 11:53:17,089  INFO TransactionManagerLookupFactory:80 - No TransactionManagerLookup configured (in JTA environment, use of read-write or transactional second-level cache is not recommended)
> 11:53:17,090  INFO SettingsFactory:169 - Automatic flush during beforeCompletion(): disabled
> 11:53:17,091  INFO SettingsFactory:173 - Automatic session close at end of transaction: disabled
> 11:53:17,097  INFO SettingsFactory:188 - Scrollable result sets: enabled
> 11:53:17,098  INFO SettingsFactory:196 - JDBC3 getGeneratedKeys(): disabled
> 11:53:17,099  INFO SettingsFactory:204 - Connection release mode: after_transaction
> 11:53:17,101  INFO SettingsFactory:231 - Default batch fetch size: 1
> 11:53:17,103  INFO SettingsFactory:235 - Generate SQL with comments: disabled
> 11:53:17,104  INFO SettingsFactory:239 - Order SQL updates by primary key: disabled
> 11:53:17,105  INFO SettingsFactory:243 - Order SQL inserts for batching: disabled
> 11:53:17,107  INFO SettingsFactory:410 - Query translator: org.hibernate.hql.ast.ASTQueryTranslatorFactory
> 11:53:17,114  INFO SettingsFactory:251 - Query language substitutions: {}
> 11:53:17,115  INFO SettingsFactory:256 - JPA-QL strict compliance: enabled
> 11:53:17,121  INFO SettingsFactory:261 - Second-level cache: enabled
> 11:53:17,130  INFO SettingsFactory:265 - Query cache: enabled
> 11:53:17,143  INFO SettingsFactory:395 - Cache region factory : org.hibernate.cache.impl.bridge.RegionFactoryCacheProviderBridge
> 11:53:17,144  INFO RegionFactoryCacheProviderBridge:61 - Cache provider: net.sf.ehcache.hibernate.SingletonEhCacheProvider
> 11:53:17,150  INFO SettingsFactory:275 - Optimize cache for minimal puts: disabled
> 11:53:17,151  INFO SettingsFactory:284 - Structured second-level cache entries: disabled
> 11:53:17,151  INFO SettingsFactory:374 - Query cache factory: org.hibernate.cache.StandardQueryCacheFactory
> 11:53:17,165  INFO SettingsFactory:313 - Statistics: disabled
> 11:53:17,166  INFO SettingsFactory:317 - Deleted entity synthetic identifier rollback: disabled
> 11:53:17,166  INFO SettingsFactory:332 - Default entity-mode: pojo
> 11:53:17,167  INFO SettingsFactory:336 - Named query checking : enabled
> 11:53:17,167  INFO SettingsFactory:340 - Check Nullability in Core (should be disabled when Bean Validation is on): disabled
> 11:53:17,240  INFO SessionFactoryImpl:197 - building session factory
> 11:53:17,260  WARN ConfigurationFactory:131 - No configuration found. Configuring ehcache from ehcache-failsafe.xml  found in the classpath: jar:file:/home/pb00067/Desktop/ehcache-1.7.1/lib/ehcache-core-1.7.1.jar!/ehcache-failsafe.xml
> 11:53:17,361  WARN SingletonEhCacheProvider:92 - Could not find a specific ehcache configuration for cache named [hello.A]; using defaults.
> 11:53:17,566  WARN SingletonEhCacheProvider:92 - Could not find a specific ehcache configuration for cache named [hello.D]; using defaults.
> 11:53:17,661  INFO SchemaExport:226 - Running hbm2ddl schema export
> 11:53:17,663  INFO SchemaExport:251 - exporting generated schema to database
> p6spy - 1264416797664|0|0|commit||
> p6spy - 1264416797670|1|0|statement
>    
>     alter table A drop constraint FK41F7BDC12E 
> p6spy - 1264416797672|0|0|statement
>    
>     drop table A if exists 
> p6spy - 1264416797673|0|0|statement
>    
>     drop table D if exists 
> p6spy - 1264416797674|1|0|statement
>    
>     drop table hibernate_sequences if exists 
> p6spy - 1264416797675|1|0|statement
>    
>     create table A (oid bigint not null, name varchar(255), version integer not null, assSingleD_oid bigint, primary key (oid), unique (name)) 
> p6spy - 1264416797676|0|0|statement
>    
>     create table D (oid bigint not null, version integer not null, primary key (oid)) 
> p6spy - 1264416797678|1|0|statement
>    
>     alter table A add constraint FK41F7BDC12E foreign key (assSingleD_oid) references D 
> p6spy - 1264416797679|1|0|statement
>    
>     create table hibernate_sequences ( sequence_name varchar(255),  sequence_next_hi_value integer )  
> 11:53:17,679  INFO SchemaExport:268 - schema export complete
> 11:53:17,684  INFO UpdateTimestampsCache:57 - starting update timestamps cache at region: org.hibernate.cache.UpdateTimestampsCache
> 11:53:17,686  WARN SingletonEhCacheProvider:92 - Could not find a specific ehcache configuration for cache named [org.hibernate.cache.UpdateTimestampsCache]; using defaults.
> 11:53:17,689  INFO StandardQueryCache:75 - starting query cache at region: org.hibernate.cache.StandardQueryCache
> 11:53:17,690  WARN SingletonEhCacheProvider:92 - Could not find a specific ehcache configuration for cache named [org.hibernate.cache.StandardQueryCache]; using defaults.
> 11:53:17,841 DEBUG ConnectionManager:444 - opening JDBC connection
> p6spy - 1264416797874|6|1|statement
>    
>     select
>         sequence_next_hi_value 
>     from
>         hibernate_sequences 
>     where
>         sequence_name = 'A' 
> p6spy - 1264416797876|0|1|statement
>    
>     insert 
>     into
>         hibernate_sequences
>         (sequence_name, sequence_next_hi_value) 
>     values
>         ('A', 0) 
> p6spy - 1264416797878|0|1|statement
>    
>     update
>         hibernate_sequences 
>     set
>         sequence_next_hi_value = 1 
>     where
>         sequence_next_hi_value = 0 
>         and sequence_name = 'A' 
> p6spy - 1264416797879|0|1|commit||
> p6spy - 1264416797915|0|0|statement
>    
>     insert 
>     into
>         A
>         (assSingleD_oid, name, version, oid) 
>     values
>         ('', 'name1', 0, 1) 
> 11:53:17,919 DEBUG UpdateTimestampsCache:66 - Pre-invalidating space [A]
> p6spy - 1264416797931|0|0|commit||
> 11:53:17,934 DEBUG UpdateTimestampsCache:81 - Invalidating space [A], timestamp: 5179051204337665
> 11:53:17,974 DEBUG StandardQueryCache:127 - checking cached query results in region: org.hibernate.cache.StandardQueryCache
> 11:53:17,975 DEBUG StandardQueryCache:132 - query results were not found in cache
> p6spy - 1264416797978|0|0|statement
>    
>     select
>         this_.oid as oid0_1_,
>         this_.assSingleD_oid as assSingleD4_0_1_,
>         this_.name as name0_1_,
>         this_.version as version0_1_,
>         d2_.oid as oid1_0_,
>         d2_.version as version1_0_ 
>     from
>         A this_ 
>     left outer join
>         D d2_ 
>             on this_.assSingleD_oid=d2_.oid 
>     where
>         (
>             this_.name='name1'
>         ) 
> p6spy - 1264416797981|-1||resultset|oid=1, oid=null
> 11:53:17,985 DEBUG StandardQueryCache:94 - caching query results in region: org.hibernate.cache.StandardQueryCache; timestamp=5179051204546560
> 11:53:17,992 DEBUG StandardQueryCache:127 - checking cached query results in region: org.hibernate.cache.StandardQueryCache
> 11:53:17,993 DEBUG StandardQueryCache:185 - Checking query spaces for up-to-dateness: [A]
> 11:53:17,994 DEBUG UpdateTimestampsCache:102 - [A] last update timestamp: 5179051204337665, result set timestamp: 5179051204546560
> 11:53:17,994 DEBUG StandardQueryCache:142 - returning cached query results
> 11:53:17,997  INFO SessionFactoryImpl:908 - closing

--
This message is automatically generated by JIRA.
For more information on JIRA, see: http://www.atlassian.com/software/jira

        


More information about the hibernate-issues mailing list