Class OrImpl
- java.lang.Object
-
- org.apache.jackrabbit.oak.query.ast.ConstraintImpl
-
- org.apache.jackrabbit.oak.query.ast.OrImpl
-
public class OrImpl extends ConstraintImpl
An "or" condition.
-
-
Constructor Summary
Constructors Constructor Description OrImpl(List<ConstraintImpl> constraints)OrImpl(ConstraintImpl constraint1, ConstraintImpl constraint2)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description booleancontainsUnfilteredFullTextCondition()Whether the condition contains a fulltext condition that can not be applied to the filter, for example because it is part of an "or" condition of the form "where a=1 or contains(., 'x')".Set<ConstraintImpl>convertToUnion()Compute a set of sub-constraints that could be used for composing UNION statements.protected PropertyValueconvertValueToType(PropertyValue v, PropertyValue targetType)org.apache.jackrabbit.oak.query.ast.AstElementcopyOf()booleanequals(Object that)booleanevaluate()Evaluate the result using the currently set values.booleanevaluateStop()Whether this condition will, from now on, always evaluate to false.List<ConstraintImpl>getConstraints()FullTextExpressiongetFullTextConstraint(SelectorImpl s)Get the (combined) full-text constraint.protected StringgetLocalPath(String path)Calculate the session local path (the path excluding the workspace name) if possible.Set<PropertyExistenceImpl>getPropertyExistenceConditions()Get the set of property existence conditions that can be derived for this condition.Set<SelectorImpl>getSelectors()Get the set of selectors for the given condition.inthashCode()protected StringnormalizePath(String path)Validate and normalize the path.protected StringnormalizePropertyName(String propertyName)Normalize the property name (including namespace remapping).protected Stringprotect(Object expression)protected static Stringquote(String pathOrName)protected static StringquoteJson(String string)booleanrequiresFullTextIndex()Whether the constraint contains a fulltext condition that requires using a fulltext index, because the condition can only be evaluated there.voidrestrict(FilterImpl f)Apply the condition to the filter, further restricting the filter if possible.voidrestrictPushDown(SelectorImpl s)Push as much of the condition down to this selector, further restricting the selector condition if possible.voidsetQuery(QueryImpl query)ConstraintImplsimplify()Simplify the expression if possible, for example by removing duplicate expressions.StringtoString()
-
-
-
Field Detail
-
query
protected QueryImpl query
-
-
Constructor Detail
-
OrImpl
public OrImpl(List<ConstraintImpl> constraints)
-
OrImpl
public OrImpl(ConstraintImpl constraint1, ConstraintImpl constraint2)
-
-
Method Detail
-
getConstraints
public List<ConstraintImpl> getConstraints()
-
simplify
public ConstraintImpl simplify()
Description copied from class:ConstraintImplSimplify the expression if possible, for example by removing duplicate expressions. For example, "x=1 or x=1" should be simplified to "x=1".- Overrides:
simplifyin classConstraintImpl- Returns:
- the simplified constraint, or "this" if it is not possible to simplify
-
getPropertyExistenceConditions
public Set<PropertyExistenceImpl> getPropertyExistenceConditions()
Description copied from class:ConstraintImplGet the set of property existence conditions that can be derived for this condition. For example, for the condition "x=1 or x=2", the property existence condition is "x is not null". For the condition "x=1 or y=2", there is no such condition. For the condition "x=1 and y=1", there are two (x is not null, and y is not null).- Specified by:
getPropertyExistenceConditionsin classConstraintImpl- Returns:
- the common property existence condition (possibly empty)
-
getFullTextConstraint
public FullTextExpression getFullTextConstraint(SelectorImpl s)
Description copied from class:ConstraintImplGet the (combined) full-text constraint. For constraints of the form "contains(*, 'x') or contains(*, 'y')", the combined expression is returned. If there is none, null is returned. For constraints of the form "contains(*, 'x') or z=1", null is returned as the full-text index cannot be used in this case for filtering (as it might filter out the z=1 nodes).- Overrides:
getFullTextConstraintin classConstraintImpl- Parameters:
s- the selector- Returns:
- the full-text constraint, if there is any, or null if not
-
getSelectors
public Set<SelectorImpl> getSelectors()
Description copied from class:ConstraintImplGet the set of selectors for the given condition.- Specified by:
getSelectorsin classConstraintImpl- Returns:
- the set of selectors (possibly empty)
-
evaluate
public boolean evaluate()
Description copied from class:ConstraintImplEvaluate the result using the currently set values.- Specified by:
evaluatein classConstraintImpl- Returns:
- true if the constraint matches
-
evaluateStop
public boolean evaluateStop()
Description copied from class:ConstraintImplWhether this condition will, from now on, always evaluate to false. This is the case for example for full-text constraints if there is no full-text index (unless FullTextComparisonWithoutIndex is enabled). This will also allow is to add conditions that stop further processing for other reasons, similar to"WHERE ROWNUM < 10"in Oracle.- Overrides:
evaluateStopin classConstraintImpl- Returns:
- true if further processing should be stopped
-
restrict
public void restrict(FilterImpl f)
Description copied from class:ConstraintImplApply the condition to the filter, further restricting the filter if possible. This may also verify the data types are compatible, and that paths are valid.- Specified by:
restrictin classConstraintImpl- Parameters:
f- the filter
-
restrictPushDown
public void restrictPushDown(SelectorImpl s)
Description copied from class:ConstraintImplPush as much of the condition down to this selector, further restricting the selector condition if possible. This is important for a join: for example, the query "select * from a inner join b on a.x=b.x where a.y=1 and b.y=1", the condition "a.y=1" can be pushed down to "a", and the condition "b.y=1" can be pushed down to "b". That means it is possible to use an index in this case.- Specified by:
restrictPushDownin classConstraintImpl- Parameters:
s- the selector
-
equals
public boolean equals(Object that)
- Overrides:
equalsin classConstraintImpl
-
hashCode
public int hashCode()
- Overrides:
hashCodein classConstraintImpl
-
copyOf
public org.apache.jackrabbit.oak.query.ast.AstElement copyOf()
- Returns:
- a clone of self. Default implementation in
AstElementreturns same reference tothis.
-
convertToUnion
public Set<ConstraintImpl> convertToUnion()
Description copied from class:ConstraintImplCompute a set of sub-constraints that could be used for composing UNION statements. For example in case of "c=1 or c=2", it will return to the caller[c=1, c=2]. Those can be later on used for re-composing conditions.If it is not possible to convert to a union, it must return an empty set.
The default implementation in
ConstraintImpl.convertToUnion()always return an empty set.- Overrides:
convertToUnionin classConstraintImpl- Returns:
- the set of union constraints, if available, or an empty set if conversion is not possible
-
requiresFullTextIndex
public boolean requiresFullTextIndex()
Description copied from class:ConstraintImplWhether the constraint contains a fulltext condition that requires using a fulltext index, because the condition can only be evaluated there.- Overrides:
requiresFullTextIndexin classConstraintImpl- Returns:
- true if yes
-
containsUnfilteredFullTextCondition
public boolean containsUnfilteredFullTextCondition()
Description copied from class:ConstraintImplWhether the condition contains a fulltext condition that can not be applied to the filter, for example because it is part of an "or" condition of the form "where a=1 or contains(., 'x')".- Overrides:
containsUnfilteredFullTextConditionin classConstraintImpl- Returns:
- true if yes
-
setQuery
public void setQuery(QueryImpl query)
-
normalizePropertyName
protected String normalizePropertyName(String propertyName)
Normalize the property name (including namespace remapping). Asterisks are kept.- Parameters:
propertyName- the property name to normalize- Returns:
- the normalized (oak-) property name
-
normalizePath
protected String normalizePath(String path)
Validate and normalize the path.- Parameters:
path- the path to validate- Returns:
- the validated and normalized path
-
convertValueToType
protected PropertyValue convertValueToType(PropertyValue v, PropertyValue targetType)
-
-