You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
179 lines
5.2 KiB
179 lines
5.2 KiB
7 years ago
|
/*
|
||
|
* Hibernate, Relational Persistence for Idiomatic Java
|
||
|
*
|
||
|
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
|
||
|
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
|
||
|
*/
|
||
|
package com.fr.third.org.hibernate;
|
||
|
import java.io.Serializable;
|
||
|
|
||
|
/**
|
||
|
* Provides an API for querying/managing the second level cache regions.
|
||
|
* <p/>
|
||
|
* CAUTION: None of these methods respect any isolation or transactional
|
||
|
* semantics associated with the underlying caches. Specifically, evictions
|
||
|
* perform an immediate "hard" removal outside any transactions and/or locking
|
||
|
* scheme(s).
|
||
|
*
|
||
|
* @author Steve Ebersole
|
||
|
*/
|
||
|
public interface Cache {
|
||
|
/**
|
||
|
* Determine whether the cache contains data for the given entity "instance".
|
||
|
* <p/>
|
||
|
* The semantic here is whether the cache contains data visible for the
|
||
|
* current call context.
|
||
|
*
|
||
|
* @param entityClass The entity class.
|
||
|
* @param identifier The entity identifier
|
||
|
*
|
||
|
* @return True if the underlying cache contains corresponding data; false
|
||
|
* otherwise.
|
||
|
*/
|
||
|
public boolean containsEntity(Class entityClass, Serializable identifier);
|
||
|
|
||
|
/**
|
||
|
* Determine whether the cache contains data for the given entity "instance".
|
||
|
* <p/>
|
||
|
* The semantic here is whether the cache contains data visible for the
|
||
|
* current call context.
|
||
|
*
|
||
|
* @param entityName The entity name.
|
||
|
* @param identifier The entity identifier
|
||
|
*
|
||
|
* @return True if the underlying cache contains corresponding data; false otherwise.
|
||
|
*/
|
||
|
public boolean containsEntity(String entityName, Serializable identifier);
|
||
|
|
||
|
/**
|
||
|
* Evicts the entity data for a particular entity "instance".
|
||
|
*
|
||
|
* @param entityClass The entity class.
|
||
|
* @param identifier The entity identifier
|
||
|
*/
|
||
|
public void evictEntity(Class entityClass, Serializable identifier);
|
||
|
|
||
|
/**
|
||
|
* Evicts the entity data for a particular entity "instance".
|
||
|
*
|
||
|
* @param entityName The entity name.
|
||
|
* @param identifier The entity identifier
|
||
|
*/
|
||
|
public void evictEntity(String entityName, Serializable identifier);
|
||
|
|
||
|
/**
|
||
|
* Evicts all entity data from the given region (i.e. for all entities of
|
||
|
* type).
|
||
|
*
|
||
|
* @param entityClass The entity class.
|
||
|
*/
|
||
|
public void evictEntityRegion(Class entityClass);
|
||
|
|
||
|
/**
|
||
|
* Evicts all entity data from the given region (i.e. for all entities of
|
||
|
* type).
|
||
|
*
|
||
|
* @param entityName The entity name.
|
||
|
*/
|
||
|
public void evictEntityRegion(String entityName);
|
||
|
|
||
|
/**
|
||
|
* Evict data from all entity regions.
|
||
|
*/
|
||
|
public void evictEntityRegions();
|
||
|
|
||
|
/**
|
||
|
* Evicts all naturalId data from the given region (i.e. for all entities of
|
||
|
* type).
|
||
|
*
|
||
|
* @param naturalIdClass The naturalId class.
|
||
|
*/
|
||
|
@SuppressWarnings( {"UnusedDeclaration"})
|
||
|
public void evictNaturalIdRegion(Class naturalIdClass);
|
||
|
|
||
|
/**
|
||
|
* Evicts all naturalId data from the given region (i.e. for all entities of
|
||
|
* type).
|
||
|
*
|
||
|
* @param naturalIdName The naturalId name.
|
||
|
*/
|
||
|
public void evictNaturalIdRegion(String naturalIdName);
|
||
|
|
||
|
/**
|
||
|
* Evict data from all naturalId regions.
|
||
|
*/
|
||
|
public void evictNaturalIdRegions();
|
||
|
|
||
|
/**
|
||
|
* Determine whether the cache contains data for the given collection.
|
||
|
* <p/>
|
||
|
* The semantic here is whether the cache contains data visible for the
|
||
|
* current call context.
|
||
|
*
|
||
|
* @param role The name of the collection role (in form
|
||
|
* [owner-entity-name].[collection-property-name]) whose regions should be
|
||
|
* evicted.
|
||
|
* @param ownerIdentifier The identifier of the owning entity
|
||
|
*
|
||
|
* @return True if the underlying cache contains corresponding data; false otherwise.
|
||
|
*/
|
||
|
@SuppressWarnings( {"UnusedDeclaration"})
|
||
|
public boolean containsCollection(String role, Serializable ownerIdentifier);
|
||
|
|
||
|
/**
|
||
|
* Evicts the cache data for the given identified collection instance.
|
||
|
*
|
||
|
* @param role The "collection role" (in form [owner-entity-name].[collection-property-name]).
|
||
|
* @param ownerIdentifier The identifier of the owning entity
|
||
|
*/
|
||
|
public void evictCollection(String role, Serializable ownerIdentifier);
|
||
|
|
||
|
/**
|
||
|
* Evicts all entity data from the given region (i.e. evicts cached data
|
||
|
* for all of the specified collection role).
|
||
|
*
|
||
|
* @param role The "collection role" (in form [owner-entity-name].[collection-property-name]).
|
||
|
*/
|
||
|
public void evictCollectionRegion(String role);
|
||
|
|
||
|
/**
|
||
|
* Evict data from all collection regions.
|
||
|
*/
|
||
|
public void evictCollectionRegions();
|
||
|
|
||
|
/**
|
||
|
* Determine whether the cache contains data for the given query.
|
||
|
* <p/>
|
||
|
* The semantic here is whether the cache contains any data for the given
|
||
|
* region name since query result caches are not transactionally isolated.
|
||
|
*
|
||
|
* @param regionName The cache name given to the query.
|
||
|
*
|
||
|
* @return True if the underlying cache contains corresponding data; false otherwise.
|
||
|
*/
|
||
|
@SuppressWarnings( {"UnusedDeclaration"})
|
||
|
public boolean containsQuery(String regionName);
|
||
|
|
||
|
/**
|
||
|
* Evicts all cached query results from the default region.
|
||
|
*/
|
||
|
public void evictDefaultQueryRegion();
|
||
|
|
||
|
/**
|
||
|
* Evicts all cached query results under the given name.
|
||
|
*
|
||
|
* @param regionName The cache name associated to the queries being cached.
|
||
|
*/
|
||
|
public void evictQueryRegion(String regionName);
|
||
|
|
||
|
/**
|
||
|
* Evict data from all query regions.
|
||
|
*/
|
||
|
public void evictQueryRegions();
|
||
|
|
||
|
/**
|
||
|
* Evict all data from the cache.
|
||
|
*/
|
||
|
public void evictAllRegions();
|
||
|
}
|