Click or drag to resize

KeyAssociatedFilter Class

Oracle® Fusion Middleware .NET API Reference for Oracle Coherence
14c (14.1.1.0)
F23534-02
IFilter which limits the scope of another filter according to the key association information.
Inheritance Hierarchy
SystemObject
  Tangosol.Util.FilterKeyAssociatedFilter

Namespace:  Tangosol.Util.Filter
Assembly:  Coherence (in Coherence.dll) Version: 14.1.1.14 (14.1.1.14)
Syntax
C#
public class KeyAssociatedFilter : IFilter, 
	IPortableObject

The KeyAssociatedFilter type exposes the following members.

Constructors
Properties
  NameDescription
Public propertyFilter
Obtain the wrapped IFilter.
Public propertyHostKey
Obtain the host key that serves as an associated key for all keys that the wrapped filter will be applied to.
Top
Methods
  NameDescription
Public methodEquals
Compare the KeyAssociatedFilter with another object to determine equality.
(Overrides ObjectEquals(Object).)
Public methodEvaluate
Apply the test to the object.
Protected methodFinalize
Allows an object to try to free resources and perform other cleanup operations before it is reclaimed by garbage collection.
(Inherited from Object.)
Public methodGetHashCode
Determine a hash value for the KeyAssociatedFilter object according to the general object.GetHashCode() contract.
(Overrides ObjectGetHashCode.)
Public methodGetType
Gets the Type of the current instance.
(Inherited from Object.)
Protected methodMemberwiseClone
Creates a shallow copy of the current Object.
(Inherited from Object.)
Public methodReadExternal
Restore the contents of a user type instance by reading its state using the specified IPofReader object.
Public methodToString
Return a human-readable description for this KeyAssociatedFilter.
(Overrides ObjectToString.)
Public methodWriteExternal
Save the contents of a POF user type instance by writing its state using the specified IPofWriter object.
Top
Remarks

This filter is intended to be used to optimize queries for partitioned caches that utilize any of the key association algorithms (by implementing either KeyAssociator or KeyAssociation) to ensure placement of all associated entries in the same distributed cache partition (and therefore in the same storage-enabled cluster node). Using the KeyAssociatedFilter will instruct the distributed cache to apply the wrapped filter only to the entries stored at the cache service node that owns the specified host key.

Note 1: This filter must be the outermost filter and cannot be used as a part of any composite filter (AndFilter, OrFilter, etc.)

Note 2: This filter is intended to be processed only on the client side of the partitioned cache service.

For example, consider two classes called Parent and Child that are stored in separate caches using ParentKey and ChildKey objects respectively. The Parent and Child classes have a Id property that returns a Long value that uniquely identifies the object. Similarly, the ParentKey and ChildKey classes have a Id property that uniquely identifies the corresponding cached object. Futhermore, the Child and ChildKey classes include a ParentId property that returns the Long identifier of the Parent object.

There are two ways to ensure that Child objects are collocated with their Parent objects (in the same storage-enabled cluster node).

  1. Make the ChildKey class implement KeyAssociation as follows:
    public Object AssociatedKey
    {
        get { return ParentId; }
    }
    and the ParentKey class implement KeyAssociation as follows:
    public Object AssociatedKey
    {
        get { return Id; }
    }
  2. Implement a custom KeyAssociator as follows:
    public object GetAssociatedKey(object key)
    {
        if (key is ChildKey)
        {
            return ((ChildKey) key).ParentId;
        }
        else if (key is ParentKey)
        {
            return ((ParentKey) key).Id;
        }
        else
        {
        return null;
        }
    }
The first approach requires a trivial change to the ChildKey and ParentKey classes, whereas the second requires a new class and a configuration change, but no changes to existing classes.

Now, to retrieve all the Child objects of a given Parent using an optimized query you would do the following:

ParentKey parentKey = new ParentKey(...);
Long      parentId  = parentKey.Id;

// this Filter will be applied to all Child objects in order to fetch
// those for which ParentId returns the specified Parent identifier
IFilter filterEq = new EqualsFilter("ParentId", parentId);

// this Filter will direct the query to the cluster node that
// currently owns the Parent object with the given identifier
IFilter filterAsc = new KeyAssociatedFilter(filterEq, parentId);

// run the optimized query to get the ChildKey objects
ICollection colChildKeys = cacheChildren.Keys(filterAsc);

// get all the Child objects at once
ICollection colChildren = cacheChildren.GetAll(colChildKeys);
To remove the Child objects you would then do the following:
cacheChildren.Keys.RemoveAll(colChildKeys);

See Also