📄 defaultevicteventlistener.java
字号:
//$Id: DefaultEvictEventListener.java,v 1.4 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.engine.Cascades;import org.hibernate.engine.EntityEntry;import org.hibernate.engine.EntityKey;import org.hibernate.engine.PersistenceContext;import org.hibernate.event.EvictEvent;import org.hibernate.event.EvictEventListener;import org.hibernate.engine.SessionImplementor;import org.hibernate.persister.entity.EntityPersister;import org.hibernate.pretty.MessageHelper;import org.hibernate.proxy.HibernateProxy;import org.hibernate.proxy.LazyInitializer;/** * Defines the default evict event listener used by hibernate for evicting entities * in response to generated flush events. In particular, this implementation will * remove any hard references to the entity that are held by the infrastructure * (references held by application or other persistent instances are okay) * * @author Steve Ebersole */public class DefaultEvictEventListener extends AbstractEventListener implements EvictEventListener { private static final Log log = LogFactory.getLog(DefaultEvictEventListener.class); /** * Handle the given evict event. * * @param event The evict event to be handled. * @throws HibernateException */ public void onEvict(EvictEvent event) throws HibernateException { SessionImplementor source = event.getSession(); final Object object = event.getObject(); final PersistenceContext persistenceContext = source.getPersistenceContext(); if ( object instanceof HibernateProxy ) { LazyInitializer li = ( (HibernateProxy) object ).getHibernateLazyInitializer(); Serializable id = li.getIdentifier(); EntityPersister persister = source.getFactory().getEntityPersister( li.getEntityName() ); EntityKey key = new EntityKey( id, persister, source.getEntityMode() ); persistenceContext.removeProxy(key); if ( !li.isUninitialized() ) { final Object entity = persistenceContext.removeEntity(key); if ( entity != null ) { EntityEntry e = event.getSession().getPersistenceContext().removeEntry(entity); doEvict( entity, key, e.getPersister(), event.getSession() ); } } } else { EntityEntry e = persistenceContext.removeEntry(object); if ( e != null ) { EntityKey key = new EntityKey( e.getId(), e.getPersister(), source.getEntityMode() ); persistenceContext.removeEntity(key); doEvict( object, key, e.getPersister(), source ); } } } protected void doEvict( final Object object, final EntityKey key, final EntityPersister persister, final SessionImplementor session) throws HibernateException { if ( log.isTraceEnabled() ) { log.trace( "evicting " + MessageHelper.infoString(persister) ); } // remove all collections for the entity from the session-level cache if ( persister.hasCollections() ) new EvictVisitor( session ).process( object, persister ); // remove any snapshot, not really for memory management purposes, but // rather because it might now be stale, and there is no longer any // EntityEntry to take precedence // This is now handled by removeEntity() //session.getPersistenceContext().removeDatabaseSnapshot(key); Cascades.cascade(session, persister, object, Cascades.ACTION_EVICT, Cascades.CASCADE_AFTER_EVICT); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -