📄 defaultinitializecollectioneventlistener.java
字号:
//$Id: DefaultInitializeCollectionEventListener.java,v 1.6 2005/02/22 03:09:34 oneovthafew Exp $package org.hibernate.event.def;import java.io.Serializable;import org.apache.commons.logging.Log;import org.apache.commons.logging.LogFactory;import org.hibernate.HibernateException;import org.hibernate.cache.CacheKey;import org.hibernate.cache.entry.CollectionCacheEntry;import org.hibernate.collection.PersistentCollection;import org.hibernate.engine.CollectionEntry;import org.hibernate.engine.PersistenceContext;import org.hibernate.engine.SessionFactoryImplementor;import org.hibernate.event.InitializeCollectionEvent;import org.hibernate.event.InitializeCollectionEventListener;import org.hibernate.engine.SessionImplementor;import org.hibernate.persister.collection.CollectionPersister;import org.hibernate.pretty.MessageHelper;/** * @author Gavin King */public class DefaultInitializeCollectionEventListener extends AbstractEventListener implements InitializeCollectionEventListener { private static final Log log = LogFactory.getLog(DefaultInitializeCollectionEventListener.class); /** * called by a collection that wants to initialize itself */ public void onInitializeCollection(InitializeCollectionEvent event) throws HibernateException { PersistentCollection collection = event.getCollection(); SessionImplementor source = event.getSession(); CollectionEntry ce = source.getPersistenceContext().getCollectionEntry(collection); if (ce==null) throw new HibernateException("collection was evicted"); if ( !ce.isInitialized() ) { if ( log.isTraceEnabled() ) log.trace( "initializing collection " + MessageHelper.collectionInfoString( ce.getLoadedPersister(), ce.getLoadedKey(), source.getFactory() ) ); log.trace("checking second-level cache"); final boolean foundInCache = initializeCollectionFromCache( ce.getLoadedKey(), ce.getLoadedPersister(), collection, source ); if (foundInCache) { log.trace("collection initialized from cache"); } else { log.trace("collection not cached"); ce.getLoadedPersister().initialize( ce.getLoadedKey(), source ); log.trace("collection initialized"); if ( source.getFactory().getStatistics().isStatisticsEnabled() ) { source.getFactory().getStatisticsImplementor().fetchCollection( ce.getLoadedPersister().getRole() ); } } } } /** * Try to initialize a collection from the cache */ private boolean initializeCollectionFromCache( Serializable id, CollectionPersister persister, PersistentCollection collection, SessionImplementor source) throws HibernateException { if ( !source.getEnabledFilters().isEmpty() && persister.isAffectedByEnabledFilters( source ) ) { log.trace( "disregarding cached version (if any) of collection due to enabled filters "); return false; } final boolean useCache = persister.hasCache() && source.getCacheMode().isGetEnabled(); if ( !useCache ) { return false; } else { final SessionFactoryImplementor factory = source.getFactory(); Object ce = persister.getCache().get( new CacheKey( id, persister.getKeyType(), persister.getRole(), source.getEntityMode() ), source.getTimestamp() ); if ( factory.getStatistics().isStatisticsEnabled() ) { if (ce==null) { factory.getStatisticsImplementor().secondLevelCacheMiss( persister.getCache().getRegionName() ); } else { factory.getStatisticsImplementor().secondLevelCacheHit( persister.getCache().getRegionName() ); } } if (ce==null) { return false; } else { CollectionCacheEntry cacheEntry = (CollectionCacheEntry) persister.getCacheEntryStructure() .destructure(ce, factory); final PersistenceContext persistenceContext = source.getPersistenceContext(); cacheEntry.assemble( collection, persister, persistenceContext.getCollectionOwner(id, persister) ); persistenceContext.getCollectionEntry(collection).postInitialize(collection); //addInitializedCollection(collection, persister, id); return true; } } }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -