Class QueryByExamplePolicy
- java.lang.Object
- 
- org.eclipse.persistence.queries.QueryByExamplePolicy
 
- 
- All Implemented Interfaces:
- java.io.Serializable
 
 public class QueryByExamplePolicy extends java.lang.Object implements java.io.SerializablePurpose: This policy defines the configuration options for a Query By Example query. Description: A Query By Example query is an ObjectLevelReadQuerywhere the selection criteria is built from an example domain object passed in viasetExampleObject.If no policy is specified the selection criteria is built from the example object in the following way: - Attributes of the example object set to nullare ignored.
- Attributes set to the default value for their primitive type (such as
 0forint) are ignored.
- Unmapped attributes are ignored.
- A domain object is returned by the query only if its values for all the included attributes equal those set in the example object.
 A policy can be set on the query to: - Always consider an attribute even if set to nullor the default value for its type. SeealwaysIncludeAttribute.
- Ignore attributes set to some other special value.  See
 excludeValue.
- Match a nullattribute on the example object with domain objects that have eithernullfor that attribute also, or have set a meaningful (notNull) value for that attribute. SeesetShouldUseEqualityForNulls(boolean).
- Use specialized operations when comparing attributes set in the example object
 with those set in the domain objects.  Matching attributes can be those with
 values greater than, less than, like, or not equal to that set in the example
 object.  See addSpecialOperation(java.lang.Class, java.lang.String).
 Note: When setting an attribute on the example object which is itself a java object with an ObjectReferenceMapping, the mapped components of that attribute will be considered, not the entire object. There is no limit to how many mapped objects can be nested inside the example object. Note: setExampleObjectis different fromsetSelectionObjectinReadObjectQuerywhich reads a single object by first extracting the primary key from the selection object.Restrictions: - Only attributes whose mappings are DirectToField, Aggregate (Embeddable), ObjectReference
 (OneToOne) or Collection type OneToMany/ManyToMany are considered in a Query By Example object.  The behaviour when an example object has attribute values for other mappings types is undefined.
 - To ensure the example does not include any unsupported mappings the flag setValidateExample(boolean)should be set to true on the corresponding QueryByExamplePolicy to ensure no unsupported relationship types are used in the example.
- For OneToMany and ManyToMany mappings the elements within the collections and the references attribute values will be added to the expression as disjuncts (OR)
 
- To ensure the example does not include any unsupported mappings the flag 
 Example: // This example uses like for Strings and the salary must be greater // than zero. ReadAllQuery query = new ReadAllQuery(); Employee employee = new Employee(); employee.setFirstName("B%"); employee.setLastName("S%"); employee.setSalary(0); query.setExampleObject(employee); QueryByExamplePolicy policy = new QueryByExamplePolicy(); policy.addSpecialOperation(String.class, "like"); policy.addSpecialOperation(Integer.class, "greaterThan"); policy.alwaysIncludeAttribute(Employee.class, "salary"); query.setQueryByExamplePolicy(policy); Vector results = (Vector) session.executeQuery(query);
- 
- 
Field SummaryFields Modifier and Type Field Description java.util.MapattributesToAlwaysIncludebooleanshouldUseEqualityForNullsjava.util.MapspecialOperationsprotected booleanvalidateExamplejava.util.MapvaluesToExclude
 - 
Constructor SummaryConstructors Constructor Description QueryByExamplePolicy()PUBLIC: Constructs a default policy equal to that used when no policy is specified.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddSpecialOperation(java.lang.Class attributeValueClass, java.lang.String operation)PUBLIC: Allows operations other thanExpression.equalto be used for comparisons.voidalwaysIncludeAttribute(java.lang.Class exampleClass, java.lang.String attributeName)PUBLIC: Always considers the value for a particular attribute as meaningful in a query by example.ExpressioncompleteExpression(Expression expression, java.lang.Object attributeValue, java.lang.Class attributeValueClass)INTERNAL: This method is used to determine which operation to use for comparison (equal, or a special operation).ExpressioncompleteExpressionForNull(Expression expression)INTERNAL: This method is used when the attribute value is null, but it has to be included at all times.voidexcludeDefaultPrimitiveValues()PUBLIC: Ignores attributes set to the default value for their primitive type.voidexcludeValue(boolean value)PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.voidexcludeValue(byte value)PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.voidexcludeValue(char value)PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.voidexcludeValue(double value)PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.voidexcludeValue(float value)PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.voidexcludeValue(int value)PUBLIC: An attribute in the example object set to be an excluded value will be ignored in a Query By Example.voidexcludeValue(long value)PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.voidexcludeValue(short value)PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.voidexcludeValue(java.lang.Object value)PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.java.util.MapgetAttributesToAlwaysInclude()PUBLIC: Attributes to always consider even if set tonullor an excluded value like0orfalse.java.lang.StringgetOperation(java.lang.Class aClass)INTERNAL: determines which operation to use for comparison.java.util.MapgetSpecialOperations()PUBLIC: The special operations to use in place ofequal.java.util.MapgetValuesToExclude()PUBLIC: Decides which attributes to ignore based on the values they are set to.voidincludeAllValues()PUBLIC: Considers all mapped attributes in the example object as meaningful in a Query By Example.booleanisAlwaysIncluded(java.lang.Class theClass, java.lang.String attributeName)INTERNAL: returns whether the attributeName is to be always included.booleanisExcludedValue(java.lang.Object value)INTERNAL: returns if the value is in the values to be excluded automatically.voidremoveFromValuesToExclude(java.lang.Object value)PUBLIC: Considers all attributes set to a previously excluded value on the example object.voidsetAttributesToAlwaysInclude(java.util.Map newAttributesToAlwaysInclude)INTERNAL: It is possible to generate a Hashtable (keys are the Class, and values the attribute names) of the attributes to be included at all times (even if the value is null, or the value belongs to the values to be excluced automatically).voidsetShouldUseEqualityForNulls(boolean shouldUseEqualityForNulls)PUBLIC: Matches an includednullattribute in the example object either to objects with that attribute also set tonullor to any value other thannull.voidsetSpecialOperations(java.util.Map newOperations)PUBLIC: The special operations to use in place ofequal.voidsetValidateExample(boolean validate)PUBLIC: When set totruethe example object will be validated for unsupported mapping types.voidsetValuesToExclude(java.util.Map newValuesToExclude)PUBLIC: Decides which attributes to ignore based on the values they are set to.booleanshouldIncludeInQuery(java.lang.Class aClass, java.lang.String attributeName, java.lang.Object attributeValue)INTERNAL: This method determines whether an attribute pair is be included in the query.booleanshouldUseEqualityForNulls()PUBLIC: Matches an includednullattribute in the example object either to objects with that attribute also set tonullor to any value other thannull.booleanshouldValidateExample()PUBLIC: Returns true if the example object used with this policy should be validated for attributes with unsupported mappings.
 
- 
- 
- 
Field Detail- 
valuesToExcludepublic java.util.Map valuesToExclude 
 - 
attributesToAlwaysIncludepublic java.util.Map attributesToAlwaysInclude 
 - 
specialOperationspublic java.util.Map specialOperations 
 - 
shouldUseEqualityForNullspublic boolean shouldUseEqualityForNulls 
 - 
validateExampleprotected boolean validateExample 
 
- 
 - 
Constructor Detail- 
QueryByExamplePolicypublic QueryByExamplePolicy() PUBLIC: Constructs a default policy equal to that used when no policy is specified.Sets the default values to be excluded, (that includes 0, false, empty String, etc). By default if an attribute is null, and yet has to be included at all times, equality (isNull) is used for the comparison. This is used for searching for an object with anullin a certain field.
 
- 
 - 
Method Detail- 
addSpecialOperationpublic void addSpecialOperation(java.lang.Class attributeValueClass, java.lang.String operation)PUBLIC: Allows operations other thanExpression.equalto be used for comparisons.For example if an attribute of type intis set toxin the example object, normally the query will be on all objects whose attributes are also equal tox. The query could however be all objects whose attributes are notx, greater thanx, or even less than or equal tox.Any comparison operation in Expressionwhich takes the example attribute as a parameter can be used. A list of supported operations is provided below.Note: A special operation can not be used for attributes set to null. The only options areisNull(default) andnotNull. SeesetShouldUseEqualityForNulls(boolean).- Parameters:
- attributeValueClass- Attribute values of which type, for instance- Integer, to apply to. Note for- intattributes the class is- Integer.classnot- int.class. This is not the- Classof the example object the attribute is an instance variable of.
- operation- Name of method in- Expressionused
- See Also:
- equal (default),- notEqual,- equalsIgnoreCase,- lessThan,- lessThanEqual,- greaterThan,- greaterThanEqual,- like,- likeIgnoreCase,- containsAllKeyWords,- containsAnyKeyWords,- containsSubstring,- containsSubstringIgnoringCase
 
 - 
alwaysIncludeAttributepublic void alwaysIncludeAttribute(java.lang.Class exampleClass, java.lang.String attributeName)PUBLIC: Always considers the value for a particular attribute as meaningful in a query by example.Required to override the normal behavior which is to ignore an attribute of the example object if set to null, or an excluded value like0.Example: To find all projects without a budget set budgetto 0 in the example object and callalwaysIncludeAttribute(Project.class, "budget")on the policy.- Parameters:
- exampleClass- The class that the attribute belongs to, normally this is the example class unless using nested QBE.
- attributeName- The name of a mapped attribute.
 
 - 
completeExpressionpublic Expression completeExpression(Expression expression, java.lang.Object attributeValue, java.lang.Class attributeValueClass) INTERNAL: This method is used to determine which operation to use for comparison (equal, or a special operation).
 - 
completeExpressionForNullpublic Expression completeExpressionForNull(Expression expression) INTERNAL: This method is used when the attribute value is null, but it has to be included at all times. It determines whether to use isNull, or notNull.
 - 
excludeDefaultPrimitiveValuespublic void excludeDefaultPrimitiveValues() PUBLIC: Ignores attributes set to the default value for their primitive type.For instance 0is used asnullfor deciding whichintattributes of the example object can be ignored in a query by example.Called by the constructor. 
 - 
excludeValuepublic void excludeValue(byte value) PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.The default excluded value for byteis0.
 - 
excludeValuepublic void excludeValue(char value) PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.The default excluded value for charis' '.
 - 
excludeValuepublic void excludeValue(double value) PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.The default excluded value for doubleis0.0.
 - 
excludeValuepublic void excludeValue(float value) PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.The default excluded value for floatis0.0f.
 - 
excludeValuepublic void excludeValue(int value) PUBLIC: An attribute in the example object set to be an excluded value will be ignored in a Query By Example.The default excluded value for intis0.
 - 
excludeValuepublic void excludeValue(long value) PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.The default excluded value for longis0.
 - 
excludeValuepublic void excludeValue(java.lang.Object value) PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.The default excluded value for Stringis"".Note: nullis special and always considered an excluded value.
 - 
excludeValuepublic void excludeValue(short value) PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.The default excluded value for shortis0.
 - 
excludeValuepublic void excludeValue(boolean value) PUBLIC: An attribute in the example object set to an excluded value will be ignored in a Query By Example.The default excluded value for booleanisfalse.
 - 
getAttributesToAlwaysIncludepublic java.util.Map getAttributesToAlwaysInclude() PUBLIC: Attributes to always consider even if set tonullor an excluded value like0orfalse.
 - 
getOperationpublic java.lang.String getOperation(java.lang.Class aClass) INTERNAL: determines which operation to use for comparison.
 - 
getSpecialOperationspublic java.util.Map getSpecialOperations() PUBLIC: The special operations to use in place ofequal.- Returns:
- A hashtable where the keys are Classobjects and the values are the names of operations to use for attributes of thatClass.
- See Also:
- addSpecialOperation(java.lang.Class, java.lang.String)
 
 - 
getValuesToExcludepublic java.util.Map getValuesToExclude() PUBLIC: Decides which attributes to ignore based on the values they are set to.If an attribute of the example domain object is set to one of these values it will be ignored, and not considered in the query. Attributes set to excluded values are not always ignored. See alwaysIncludeAttribute.- Returns:
- valuesToExclude The keys and values are values to exclude (key == value).  Primitives are
 wrapped, so int 0will be stored asInteger(0).
- See Also:
- excludeValue(byte),- excludeDefaultPrimitiveValues(),- includeAllValues()
 
 - 
includeAllValuespublic void includeAllValues() PUBLIC: Considers all mapped attributes in the example object as meaningful in a Query By Example.Note: Even attributes of the example object that are not set, and therefore zero or empty by default, will be included. Reverses a previous call to excludeDefaultPrimitiveValues().
 - 
isAlwaysIncludedpublic boolean isAlwaysIncluded(java.lang.Class theClass, java.lang.String attributeName)INTERNAL: returns whether the attributeName is to be always included.
 - 
isExcludedValuepublic boolean isExcludedValue(java.lang.Object value) INTERNAL: returns if the value is in the values to be excluded automatically.
 - 
removeFromValuesToExcludepublic void removeFromValuesToExclude(java.lang.Object value) PUBLIC: Considers all attributes set to a previously excluded value on the example object.Primitive values to be removed must first be wrapped inside an Object. - Parameters:
- value- No attributes set to- valuewill be excluded from a Query By Example.- value.getClass()is a key of the Hashtable returned by- getValuesToExclude().- Note: There is a distinction between an attribute and the value it is set to. An attribute can be included independently of its value with - alwaysIncludeAttribute(recommended). It can also be included by making the value it is set to no longer excluded.- Note: - nullvalues are special and will always be excluded.
- See Also:
- excludeDefaultPrimitiveValues(),- includeAllValues(),- excludeValue(Object)
 
 - 
setAttributesToAlwaysIncludepublic void setAttributesToAlwaysInclude(java.util.Map newAttributesToAlwaysInclude) INTERNAL: It is possible to generate a Hashtable (keys are the Class, and values the attribute names) of the attributes to be included at all times (even if the value is null, or the value belongs to the values to be excluced automatically).
 - 
setShouldUseEqualityForNullspublic void setShouldUseEqualityForNulls(boolean shouldUseEqualityForNulls) PUBLIC: Matches an includednullattribute in the example object either to objects with that attribute also set tonullor to any value other thannull.Set to falseto only select objects where certain attributes have been set.Example: to find all Employees with an assigned address, set attributeaddresstonullin the example object, callalwaysIncludeAttribute(Employee.class, "address")and then callsetShouldUseEqualityForNulls(false).Note: Unless an attribute set to nullis specifically included, it will not be considered at all in the Query By Example.- Parameters:
- shouldUseEqualityForNulls- If true (by default) uses- isNullelse- notNull.
- See Also:
- addSpecialOperation,- alwaysIncludeAttribute
 
 - 
setSpecialOperationspublic void setSpecialOperations(java.util.Map newOperations) PUBLIC: The special operations to use in place ofequal.- Parameters:
- newOperations- A hashtable where the keys are- Classobjects and the values are the names of operations to use for attributes of that- Class.
- See Also:
- addSpecialOperation(java.lang.Class, java.lang.String)
 
 - 
setValidateExamplepublic void setValidateExample(boolean validate) PUBLIC: When set totruethe example object will be validated for unsupported mapping types. If you wish these mapping types to be ignored either set this flag tofalseor add the attribute to the list of ignored attributes in this policy
 - 
setValuesToExcludepublic void setValuesToExclude(java.util.Map newValuesToExclude) PUBLIC: Decides which attributes to ignore based on the values they are set to.An attribute of the example domain object set to one of these values will be ignored, and not considered in the query. Attributes set to excluded values are not always ignored. See alwaysIncludeAttribute.- Parameters:
- newValuesToExclude- The keys and values are values to exclude (key == value). Primitives are wrapped, so- int 0will be stored as- Integer(0).
- See Also:
- excludeValue(byte),- excludeDefaultPrimitiveValues(),- includeAllValues()
 
 - 
shouldIncludeInQuerypublic boolean shouldIncludeInQuery(java.lang.Class aClass, java.lang.String attributeName, java.lang.Object attributeValue)INTERNAL: This method determines whether an attribute pair is be included in the query.
 - 
shouldUseEqualityForNullspublic boolean shouldUseEqualityForNulls() PUBLIC: Matches an includednullattribute in the example object either to objects with that attribute also set tonullor to any value other thannull.Set to falseto only select objects where certain attributes have been set.Example: to find all Employees with an assigned address, set attributeaddresstonullin the example object, callalwaysIncludeAttribute(Employee.class, "address")and then callsetShouldUseEqualityForNulls(false).- Returns:
- If true (by default) uses isNullelsenotNull.
- See Also:
- addSpecialOperation,- alwaysIncludeAttribute
 
 - 
shouldValidateExamplepublic boolean shouldValidateExample() PUBLIC: Returns true if the example object used with this policy should be validated for attributes with unsupported mappings.
 
- 
 
-