public class

CollectionAccessStrategyAdapter

extends Object
implements CollectionRegionAccessStrategy
java.lang.Object
   ↳ org.hibernate.cache.impl.bridge.CollectionAccessStrategyAdapter

Class Overview

Adapter specifically bridging CollectionRegionAccessStrategy to CacheConcurrencyStrategy.

Summary

Public Constructors
CollectionAccessStrategyAdapter(CollectionRegion region, CacheConcurrencyStrategy ccs, Settings settings)
Public Methods
void destroy()
void evict(Object key)
Forcibly evict an item from the cache immediately without regard for transaction isolation.
void evictAll()
Forcibly evict all items from the cache immediately without regard for transaction isolation.
Object get(Object key, long txTimestamp)
Attempt to retrieve an object from the cache.
CollectionRegion getRegion()
Get the wrapped collection cache region
SoftLock lockItem(Object key, Object version)
We are going to attempt to update/delete the keyed object.
SoftLock lockRegion()
Lock the entire region
boolean putFromLoad(Object key, Object value, long txTimestamp, Object version, boolean minimalPutOverride)
Attempt to cache an object, after loading from the database, explicitly specifying the minimalPut behavior.
boolean putFromLoad(Object key, Object value, long txTimestamp, Object version)
Attempt to cache an object, after loading from the database.
void remove(Object key)
Called after an item has become stale (before the transaction completes).
void removeAll()
Called to evict data from the entire region
void unlockItem(Object key, SoftLock lock)
Called when we have finished the attempted update/delete (which may or may not have been successful), after transaction completion.
void unlockRegion(SoftLock lock)
Called after we have finished the attempted invalidation of the entire region
[Expand]
Inherited Methods
From class java.lang.Object
From interface org.hibernate.cache.access.CollectionRegionAccessStrategy

Public Constructors

public CollectionAccessStrategyAdapter (CollectionRegion region, CacheConcurrencyStrategy ccs, Settings settings)

Public Methods

public void destroy ()

public void evict (Object key)

Forcibly evict an item from the cache immediately without regard for transaction isolation.

Parameters
key The key of the item to remove

public void evictAll ()

Forcibly evict all items from the cache immediately without regard for transaction isolation.

public Object get (Object key, long txTimestamp)

Attempt to retrieve an object from the cache. Mainly used in attempting to resolve entities/collections from the second level cache.

Parameters
key The key of the item to be retrieved.
txTimestamp a timestamp prior to the transaction start time
Returns
  • the cached object or null

public CollectionRegion getRegion ()

Get the wrapped collection cache region

Returns
  • The underlying region

public SoftLock lockItem (Object key, Object version)

We are going to attempt to update/delete the keyed object. This method is used by "asynchronous" concurrency strategies.

The returned object must be passed back to release(), to release the lock. Concurrency strategies which do not support client-visible locks may silently return null.

Parameters
key The key of the item to lock
version The item's current version value
Returns
  • A representation of our lock on the item; or null.

public SoftLock lockRegion ()

Lock the entire region

Returns
  • A representation of our lock on the item; or null.

public boolean putFromLoad (Object key, Object value, long txTimestamp, Object version, boolean minimalPutOverride)

Attempt to cache an object, after loading from the database, explicitly specifying the minimalPut behavior.

Parameters
key The item key
value The item
txTimestamp a timestamp prior to the transaction start time
version the item version number
minimalPutOverride Explicit minimalPut flag
Returns
  • true if the object was successfully cached

public boolean putFromLoad (Object key, Object value, long txTimestamp, Object version)

Attempt to cache an object, after loading from the database.

Parameters
key The item key
value The item
txTimestamp a timestamp prior to the transaction start time
version the item version number
Returns
  • true if the object was successfully cached

public void remove (Object key)

Called after an item has become stale (before the transaction completes). This method is used by "synchronous" concurrency strategies.

Parameters
key The key of the item to remove

public void removeAll ()

Called to evict data from the entire region

public void unlockItem (Object key, SoftLock lock)

Called when we have finished the attempted update/delete (which may or may not have been successful), after transaction completion. This method is used by "asynchronous" concurrency strategies.

Parameters
key The item key
lock The lock previously obtained from lockItem(Object, Object)

public void unlockRegion (SoftLock lock)

Called after we have finished the attempted invalidation of the entire region

Parameters
lock The lock previously obtained from lockRegion()