Class FullTextSearchImpl
- java.lang.Object
-
- org.apache.jackrabbit.oak.query.ast.ConstraintImpl
-
- org.apache.jackrabbit.oak.query.ast.FullTextSearchImpl
-
- Direct Known Subclasses:
NotFullTextSearchImpl
public class FullTextSearchImpl extends ConstraintImpl
A fulltext "contains(...)" condition.
-
-
Constructor Summary
Constructors Constructor Description FullTextSearchImpl(String selectorName, String propertyName, StaticOperandImpl fullTextSearchExpression)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
bindSelector(SourceImpl source)
protected PropertyValue
convertValueToType(PropertyValue v, PropertyValue targetType)
org.apache.jackrabbit.oak.query.ast.AstElement
copyOf()
boolean
evaluate()
Evaluate the result using the currently set values.boolean
evaluateStop()
Whether this condition will, from now on, always evaluate to false.FullTextExpression
getFullTextConstraint(SelectorImpl s)
Get the (combined) full-text constraint.StaticOperandImpl
getFullTextSearchExpression()
protected String
getLocalPath(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.protected String
normalizePath(String path)
Validate and normalize the path.protected String
normalizePropertyName(String propertyName)
Normalize the property name (including namespace remapping).protected String
protect(Object expression)
protected String
quote(String pathOrName)
protected String
quoteJson(String string)
boolean
requiresFullTextIndex()
Whether the constraint contains a fulltext condition that requires using a fulltext index, because the condition can only be evaluated there.void
restrict(FilterImpl f)
Apply the condition to the filter, further restricting the filter if possible.void
restrictPushDown(SelectorImpl s)
Push as much of the condition down to this selector, further restricting the selector condition if possible.void
setQuery(QueryImpl query)
String
toString()
-
Methods inherited from class org.apache.jackrabbit.oak.query.ast.ConstraintImpl
containsUnfilteredFullTextCondition, convertToUnion, equals, hashCode, simplify
-
-
-
-
Field Detail
-
query
protected QueryImpl query
-
-
Constructor Detail
-
FullTextSearchImpl
public FullTextSearchImpl(String selectorName, String propertyName, StaticOperandImpl fullTextSearchExpression)
-
-
Method Detail
-
getFullTextSearchExpression
public StaticOperandImpl getFullTextSearchExpression()
-
getPropertyExistenceConditions
public Set<PropertyExistenceImpl> getPropertyExistenceConditions()
Description copied from class:ConstraintImpl
Get 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:
getPropertyExistenceConditions
in classConstraintImpl
- Returns:
- the common property existence condition (possibly empty)
-
getFullTextConstraint
public FullTextExpression getFullTextConstraint(SelectorImpl s)
Description copied from class:ConstraintImpl
Get 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:
getFullTextConstraint
in 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:ConstraintImpl
Get the set of selectors for the given condition.- Specified by:
getSelectors
in classConstraintImpl
- Returns:
- the set of selectors (possibly empty)
-
evaluate
public boolean evaluate()
Description copied from class:ConstraintImpl
Evaluate the result using the currently set values.- Specified by:
evaluate
in classConstraintImpl
- Returns:
- true if the constraint matches
-
evaluateStop
public boolean evaluateStop()
Description copied from class:ConstraintImpl
Whether 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:
evaluateStop
in classConstraintImpl
- Returns:
- true if further processing should be stopped
-
bindSelector
public void bindSelector(SourceImpl source)
-
restrict
public void restrict(FilterImpl f)
Description copied from class:ConstraintImpl
Apply 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:
restrict
in classConstraintImpl
- Parameters:
f
- the filter
-
restrictPushDown
public void restrictPushDown(SelectorImpl s)
Description copied from class:ConstraintImpl
Push 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:
restrictPushDown
in classConstraintImpl
- Parameters:
s
- the selector
-
copyOf
public org.apache.jackrabbit.oak.query.ast.AstElement copyOf()
- Returns:
- a clone of self. Default implementation in
AstElement
returns same reference tothis
.
-
requiresFullTextIndex
public boolean requiresFullTextIndex()
Description copied from class:ConstraintImpl
Whether the constraint contains a fulltext condition that requires using a fulltext index, because the condition can only be evaluated there.- Overrides:
requiresFullTextIndex
in 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)
-
-