Package org.apache.cayenne.exp
Class Expression
java.lang.Object
org.apache.cayenne.exp.Expression
- All Implemented Interfaces:
- Serializable,- XMLSerializable
- Direct Known Subclasses:
- SimpleNode
Superclass of Cayenne expressions that defines basic API for expressions use.
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intExpression describes a path relative to a DbEntity.static final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intInterpreted as a comma-separated list of literals.static final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intExpression describes a path relative to an ObjEntity.static final intstatic final ObjectA value that a Transformer might return to indicate that a node has to be pruned from the expression during the transformation.static final intstatic final intstatic final intstatic final intstatic final intprotected intstatic final int
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionandExp(Expression exp) Chains this expression with another expression using "and".andExp(Expression exp, Expression... expressions) Chains this expression with other expressions using "and".voidappendAsEJBQL(Appendable out, String rootId) Stores a String representation of Expression as EJBQL using a provided Appendable.abstract voidappendAsEJBQL(List<Object> parameterAccumulator, Appendable out, String rootId) Stores a String representation of Expression as EJBQL using a provided PrintWriter.abstract voidappendAsString(Appendable out) Appends own content as a String to the provided Appendable.deepCopy()Clones this expression.voidencodeAsXML(XMLEncoder encoder, ConfigurationNodeVisitor delegate) Encodes itself, wrapping the string into XML CDATA section.booleanabstract ObjectCalculates expression value with object as a context for path expressions.abstract Expressionexists()Returns expression that will be dynamically resolved to proper subqueries based on a relationships used (if no relationships are present in the original expression no subqueries will be used).expName()Returns String label for this expression.<T> Collection<?>filter(Collection<T> source, Collection<T> target) Adds objects matching this expression from the source collection to the target collection.<T> List<T>filterObjects(Collection<T> objects) Returns a list of objects that match the expression.<T> TReturns the first object in the list that matches the expression.protected abstract voidRestructures expression to make sure that there are no children of the same type as this expression.abstract ObjectgetOperand(int index) Returns a value of operand atindex.abstract intReturns a count of operands of this expression.Returns a map of path aliases for this expression.intgetType()Returns a type of expression.inthashCode()joinExp(int type, Expression exp) Creates a new expression that joins this object with another expression, using specified join type.joinExp(int type, Expression exp, Expression... expressions) Creates a new expression that joins this object with other expressions, using specified join type.booleanCalculates expression boolean value with object as a context for path expressions.abstract ExpressionReturns expression that will be dynamically resolved to proper subqueries based on a relationships used (if no relationships are present in the original expression no subqueries will be used).abstract ExpressionnotExp()Returns a logical NOT of current expression.orExp(Expression exp) Chains this expression with another expression using "or".orExp(Expression exp, Expression... expressions) Chains this expression with other expressions using "or".Creates and returns a new Expression instance based on this expression, but with named parameters substituted with provided values.Creates and returns a new Expression instance based on this expression, but with named parameters substituted with provided values.If any subexpressions containing parameters not matching the "name" argument are found, the behavior depends on "pruneMissing" argument.paramsArray(Object... parameters) Creates and returns a new Expression instance based on this expression, but with parameters substituted with provided values.protected abstract booleanpruneNodeForPrunedChild(Object prunedChild) Returns true if this node should be pruned from expression tree in the event a child is removed.abstract voidsetOperand(int index, Object value) Sets a value of operand atindex.voidsetType(int type) abstract ExpressionCreates a copy of this expression node, without copying children.Produces an EJBQL string that represents this expression.Produces an EJBQL string that represents this expression.toString()Creates a transformed copy of this expression, applying transformation provided by Transformer to all its nodes.protected ObjecttransformExpression(Function<Object, Object> transformer) A recursive method called from "transform" to do the actual transformation.protected voidtraverse(Expression parentExp, TraversalHandler visitor) Traverses itself and child expressions, notifying visitor via callback methods as it goes.voidtraverse(TraversalHandler visitor) Traverses itself and child expressions, notifying visitor via callback methods as it goes.
- 
Field Details- 
PRUNED_NODEA value that a Transformer might return to indicate that a node has to be pruned from the expression during the transformation.- Since:
- 1.2
 
- 
ANDpublic static final int AND- See Also:
 
- 
ORpublic static final int OR- See Also:
 
- 
NOTpublic static final int NOT- See Also:
 
- 
EQUAL_TOpublic static final int EQUAL_TO- See Also:
 
- 
NOT_EQUAL_TOpublic static final int NOT_EQUAL_TO- See Also:
 
- 
LESS_THANpublic static final int LESS_THAN- See Also:
 
- 
GREATER_THANpublic static final int GREATER_THAN- See Also:
 
- 
LESS_THAN_EQUAL_TOpublic static final int LESS_THAN_EQUAL_TO- See Also:
 
- 
GREATER_THAN_EQUAL_TOpublic static final int GREATER_THAN_EQUAL_TO- See Also:
 
- 
BETWEENpublic static final int BETWEEN- See Also:
 
- 
INpublic static final int IN- See Also:
 
- 
LIKEpublic static final int LIKE- See Also:
 
- 
LIKE_IGNORE_CASEpublic static final int LIKE_IGNORE_CASE- See Also:
 
- 
ADDpublic static final int ADD- See Also:
 
- 
SUBTRACTpublic static final int SUBTRACT- See Also:
 
- 
MULTIPLYpublic static final int MULTIPLY- See Also:
 
- 
DIVIDEpublic static final int DIVIDE- See Also:
 
- 
NEGATIVEpublic static final int NEGATIVE- See Also:
 
- 
TRUEpublic static final int TRUE- See Also:
 
- 
FALSEpublic static final int FALSE- See Also:
 
- 
OBJ_PATHpublic static final int OBJ_PATHExpression describes a path relative to an ObjEntity. OBJ_PATH expression is resolved relative to some root ObjEntity. Path expression components are separated by "." (dot). Path can point to either one of these:- An attribute of root ObjEntity. For entity Gallery OBJ_PATH expression "galleryName" will point to ObjAttribute "galleryName"
- Another ObjEntity related to root ObjEntity via a chain of relationships. For entity Gallery OBJ_PATH expression "paintingArray.toArtist" will point to ObjEntity "Artist"
- ObjAttribute of another ObjEntity related to root ObjEntity via a chain of relationships. For entity Gallery OBJ_PATH expression "paintingArray.toArtist.artistName" will point to ObjAttribute "artistName"
 - See Also:
 
- 
DB_PATHpublic static final int DB_PATHExpression describes a path relative to a DbEntity. DB_PATH expression is resolved relative to some root DbEntity. Path expression components are separated by "." (dot). Path can point to either one of these:- An attribute of root DbEntity. For entity GALLERY, DB_PATH expression "GALLERY_NAME" will point to a DbAttribute "GALLERY_NAME".
- Another DbEntity related to root DbEntity via a chain of relationships. For entity GALLERY DB_PATH expression "paintingArray.toArtist" will point to DbEntity "ARTIST".
- DbAttribute of another ObjEntity related to root DbEntity via a chain of relationships. For entity GALLERY DB_PATH expression "paintingArray.toArtist.ARTIST_NAME" will point to DbAttribute "ARTIST_NAME".
 - See Also:
 
- 
LISTpublic static final int LISTInterpreted as a comma-separated list of literals.- See Also:
 
- 
NOT_BETWEENpublic static final int NOT_BETWEEN- See Also:
 
- 
NOT_INpublic static final int NOT_IN- See Also:
 
- 
NOT_LIKEpublic static final int NOT_LIKE- See Also:
 
- 
NOT_LIKE_IGNORE_CASEpublic static final int NOT_LIKE_IGNORE_CASE- See Also:
 
- 
BITWISE_NOTpublic static final int BITWISE_NOT- Since:
- 3.1
- See Also:
 
- 
BITWISE_ANDpublic static final int BITWISE_AND- Since:
- 3.1
- See Also:
 
- 
BITWISE_ORpublic static final int BITWISE_OR- Since:
- 3.1
- See Also:
 
- 
BITWISE_XORpublic static final int BITWISE_XOR- Since:
- 3.1
- See Also:
 
- 
BITWISE_LEFT_SHIFTpublic static final int BITWISE_LEFT_SHIFT- Since:
- 4.0
- See Also:
 
- 
BITWISE_RIGHT_SHIFTpublic static final int BITWISE_RIGHT_SHIFT- Since:
- 4.0
- See Also:
 
- 
FUNCTION_CALLpublic static final int FUNCTION_CALL- Since:
- 4.0
- See Also:
 
- 
ASTERISKpublic static final int ASTERISK- Since:
- 4.0
- See Also:
 
- 
FULL_OBJECTpublic static final int FULL_OBJECT- Since:
- 4.0
- See Also:
 
- 
ENCLOSING_OBJECTpublic static final int ENCLOSING_OBJECT- Since:
- 4.2
- See Also:
 
- 
EXISTSpublic static final int EXISTS- Since:
- 4.2
- See Also:
 
- 
NOT_EXISTSpublic static final int NOT_EXISTS- Since:
- 4.2
- See Also:
 
- 
SUBQUERYpublic static final int SUBQUERY- Since:
- 4.2
- See Also:
 
- 
DBID_PATHpublic static final int DBID_PATH- Since:
- 4.2
- See Also:
 
- 
CUSTOM_OPpublic static final int CUSTOM_OP- Since:
- 4.2
- See Also:
 
- 
ALLpublic static final int ALL- Since:
- 5.0
- See Also:
 
- 
ANYpublic static final int ANY- Since:
- 5.0
- See Also:
 
- 
SCALARpublic static final int SCALAR- Since:
- 5.0
- See Also:
 
- 
CASE_WHENpublic static final int CASE_WHEN- Since:
- 5.0
- See Also:
 
- 
WHENpublic static final int WHEN- Since:
- 5.0
- See Also:
 
- 
THENpublic static final int THEN- Since:
- 5.0
- See Also:
 
- 
ELSEpublic static final int ELSE- Since:
- 5.0
- See Also:
 
- 
typeprotected int type
 
- 
- 
Constructor Details- 
Expressionpublic Expression()
 
- 
- 
Method Details- 
getPathAliasesReturns a map of path aliases for this expression. It returns a non-empty map only if this is a path expression and the aliases are known at the expression creation time. Otherwise an empty map is returned.- Since:
- 3.0
 
- 
expNameReturns String label for this expression. Used for debugging.
- 
equals
- 
hashCodepublic int hashCode()
- 
getTypepublic int getType()Returns a type of expression. Most common types are defined as public static fields of this interface.
- 
setTypepublic void setType(int type) 
- 
paramsArrayCreates and returns a new Expression instance based on this expression, but with parameters substituted with provided values. This is a positional style of binding. If a given parameter name is used more than once, only the first occurrence is treated as "position", subsequent occurrences are bound with the same value as the first one. If expression parameters count is different from the array parameter count, an exception will be thrown.positional style would not allow subexpression pruning. - Since:
- 4.0
 
- 
paramsCreates and returns a new Expression instance based on this expression, but with named parameters substituted with provided values. Any subexpressions containing parameters not matching the "name" argument will be pruned.Note that if you want matching against nulls to be preserved, you must place NULL values for the corresponding keys in the map. - Since:
- 4.0
 
- 
paramsCreates and returns a new Expression instance based on this expression, but with named parameters substituted with provided values.If any subexpressions containing parameters not matching the "name" argument are found, the behavior depends on "pruneMissing" argument. If it is false an Exception will be thrown, otherwise subexpressions with missing parameters will be pruned from the resulting expression.Note that if you want matching against nulls to be preserved, you must place NULL values for the corresponding keys in the map. - Since:
- 4.0
 
- 
joinExpCreates a new expression that joins this object with another expression, using specified join type. It is very useful for incrementally building chained expressions, like long AND or OR statements.
- 
joinExpCreates a new expression that joins this object with other expressions, using specified join type. It is very useful for incrementally building chained expressions, like long AND or OR statements.- Since:
- 4.0
 
- 
andExpChains this expression with another expression using "and".
- 
andExpChains this expression with other expressions using "and".- Since:
- 4.0
 
- 
orExpChains this expression with another expression using "or".
- 
orExpChains this expression with other expressions using "or".- Since:
- 4.0
 
- 
notExpReturns a logical NOT of current expression.- Since:
- 1.0.6
 
- 
existsReturns expression that will be dynamically resolved to proper subqueries based on a relationships used (if no relationships are present in the original expression no subqueries will be used).- Returns:
- exists expression
- Since:
- 5.0
- See Also:
 
- 
notExistsReturns expression that will be dynamically resolved to proper subqueries based on a relationships used (if no relationships are present in the original expression no subqueries will be used).- Returns:
- not exists expression
- Since:
- 5.0
- See Also:
 
- 
getOperandCountpublic abstract int getOperandCount()Returns a count of operands of this expression. In real life there are unary (count == 1), binary (count == 2) and ternary (count == 3) expressions.
- 
getOperandReturns a value of operand atindex. Operand indexing starts at 0.
- 
setOperandSets a value of operand atindex. Operand indexing starts at 0.
- 
evaluateCalculates expression value with object as a context for path expressions.- Since:
- 1.1
 
- 
matchCalculates expression boolean value with object as a context for path expressions.- Since:
- 1.1
 
- 
firstReturns the first object in the list that matches the expression.- Since:
- 3.1
 
- 
filterObjectsReturns a list of objects that match the expression.
- 
filterAdds objects matching this expression from the source collection to the target collection.- Since:
- 1.1
 
- 
deepCopyClones this expression.- Since:
- 1.1
 
- 
shallowCopyCreates a copy of this expression node, without copying children.- Since:
- 1.1
 
- 
pruneNodeForPrunedChildReturns true if this node should be pruned from expression tree in the event a child is removed.- Since:
- 1.1
 
- 
flattenTreeprotected abstract void flattenTree()Restructures expression to make sure that there are no children of the same type as this expression.- Since:
- 1.1
 
- 
traverseTraverses itself and child expressions, notifying visitor via callback methods as it goes. This is an Expression-specific implementation of the "Visitor" design pattern.- Since:
- 1.1
 
- 
traverseTraverses itself and child expressions, notifying visitor via callback methods as it goes.- Since:
- 1.1
 
- 
transformCreates a transformed copy of this expression, applying transformation provided by Transformer to all its nodes. Null transformer will result in an identical deep copy of this expression.To force a node and its children to be pruned from the copy, Transformer should return Expression.PRUNED_NODE. Otherwise an expectation is that if a node is an Expression it must be transformed to null or another Expression. Any other object type would result in a ExpressionException. - Since:
- 1.1
 
- 
transformExpressionA recursive method called from "transform" to do the actual transformation.- Returns:
- null, Expression.PRUNED_NODE or transformed expression.
- Since:
- 1.2
 
- 
encodeAsXMLEncodes itself, wrapping the string into XML CDATA section.- Specified by:
- encodeAsXMLin interface- XMLSerializable
- Since:
- 1.1
 
- 
appendAsStringAppends own content as a String to the provided Appendable.- Throws:
- IOException
- Since:
- 4.0
 
- 
appendAsEJBQLStores a String representation of Expression as EJBQL using a provided Appendable. DB path expressions produce non-standard EJBQL path expressions.- Throws:
- IOException
- Since:
- 4.0
 
- 
appendAsEJBQLpublic abstract void appendAsEJBQL(List<Object> parameterAccumulator, Appendable out, String rootId) throws IOException Stores a String representation of Expression as EJBQL using a provided PrintWriter. DB path expressions produce non-standard EJBQL path expressions. If the parameterAccumulator is supplied then as the EJBQL is output, it may load parameters into this list. In this case, the EJBQL output will contain reference to positional parameters. If no parameterAccumulator is supplied and a scalar type is encountered for which there is no EJBQL literal representation (such as dates) then this method will throw a runtime exception to indicate that it was not possible to generate a string-only representation of the Expression in EJBQL.- Throws:
- IOException
- Since:
- 4.0
 
- 
toString
- 
toEJBQLProduces an EJBQL string that represents this expression. If the parameterAccumulator is supplied then, where appropriate, parameters to the EJBQL may be written into the parameterAccumulator. If this method encounters a scalar type which is not able to be represented as an EJBQL literal then this method will throw a runtime exception to indicate that it was not possible to generate a string-only representation of the Expression as EJBQL.- Since:
- 3.1
 
- 
toEJBQLProduces an EJBQL string that represents this expression. If this method encounters a scalar type which is not able to be represented as an EJBQL literal then this method will throw a runtime exception.- Since:
- 3.0
 
 
-