Package mondrian.rolap.agg
Class ListColumnPredicate
java.lang.Object
mondrian.rolap.agg.AbstractColumnPredicate
mondrian.rolap.agg.ListColumnPredicate
- All Implemented Interfaces:
StarColumnPredicate,StarPredicate
Predicate which is the union of a list of predicates, each of which applies
to the same, single column. It evaluates to
true if any of the predicates evaluates to true.
- Since:
- Nov 2, 2006
- Author:
- jhyde
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class mondrian.rolap.agg.AbstractColumnPredicate
AbstractColumnPredicate.FactoryNested classes/interfaces inherited from interface mondrian.rolap.StarColumnPredicate
StarColumnPredicate.Overlap -
Field Summary
Fields inherited from class mondrian.rolap.agg.AbstractColumnPredicate
constrainedColumnFields inherited from interface mondrian.rolap.StarPredicate
WILDCARD -
Constructor Summary
ConstructorsConstructorDescriptionListColumnPredicate(RolapStar.Column column, List<StarColumnPredicate> list) Creates a ListColumnPredicate -
Method Summary
Modifier and TypeMethodDescriptioncloneWithColumn(RolapStar.Column column) This method is required because unfortunately some ColumnPredicate objects are created without a column.voiddescribe(StringBuilder buf) Appends a description of this predicate to aStringBuilder.booleanequalConstraint(StarPredicate that) Returns whether this Predicate has the same constraining effect as the other constraint.booleanbooleanReturns whether this constraint would returntruefor a given value.Returns the list of child predicates.inthashCode()intersect(StarColumnPredicate predicate) Applies this predicate to a predicate from the axis of a segment, and tests for overlap.booleanmightIntersect(StarPredicate other) Returns whether this predicate might intersect another predicate.minus(StarPredicate predicate) Returns the logical inverse of this Predicate.orColumn(StarColumnPredicate predicate) Returns this union of this Predicate with another.voidtoSql(SqlQuery sqlQuery, StringBuilder buf) voidvalues(Collection<Object> collection) Adds the values in this constraint to a collection.Methods inherited from class mondrian.rolap.agg.AbstractColumnPredicate
and, cloneListWithColumn, evaluate, getConstrainedColumn, getConstrainedColumnBitKey, getConstrainedColumnList, or, toString
-
Constructor Details
-
ListColumnPredicate
Creates a ListColumnPredicate- Parameters:
column- Column being constrainedlist- List of child predicates
-
-
Method Details
-
getPredicates
Returns the list of child predicates.- Returns:
- list of child predicates
-
hashCode
public int hashCode() -
equals
-
values
Description copied from interface:StarColumnPredicateAdds the values in this constraint to a collection.- Parameters:
collection- Collection to add values to
-
evaluate
Description copied from interface:StarColumnPredicateReturns whether this constraint would returntruefor a given value.- Parameters:
value- Value- Returns:
- Whether predicate is true
-
equalConstraint
Description copied from interface:StarPredicateReturns whether this Predicate has the same constraining effect as the other constraint. This is weaker thanObject.equals(Object): it is possible for two different members to constrain the same column in the same way.- Specified by:
equalConstraintin interfaceStarPredicate- Overrides:
equalConstraintin classAbstractColumnPredicate- Parameters:
that- Other predicate- Returns:
- whether the other predicate is equivalent
-
describe
Description copied from interface:StarPredicateAppends a description of this predicate to aStringBuilder. For example:- =any
- =5
- in (2, 4, 6)
- Parameters:
buf- Builder to append to
-
intersect
Description copied from interface:StarColumnPredicateApplies this predicate to a predicate from the axis of a segment, and tests for overlap. The result might be that there is no overlap, full overlap (so the constraint can be removed), or partial overlap (so the constraint will need to be replaced with a stronger constraint, say 'x > 10' is replaced with 'x > 20').- Parameters:
predicate- Predicate- Returns:
- description of overlap between predicates, if any
-
mightIntersect
Description copied from interface:StarColumnPredicateReturns whether this predicate might intersect another predicate. That is, whether there might be a value which holds true for both constraints.- Parameters:
other- Other constraint- Returns:
- Whether constraints intersect
-
minus
Description copied from interface:StarPredicateReturns the logical inverse of this Predicate. The result is a Predicate which holds whenever this predicate holds but the other does not.- Parameters:
predicate- Predicate- Returns:
- Combined predicate
-
orColumn
Description copied from interface:StarColumnPredicateReturns this union of this Predicate with another.Unlike
StarPredicate.or(mondrian.rolap.StarPredicate), the other predicate must be on this column, and the result is a column predicate.- Specified by:
orColumnin interfaceStarColumnPredicate- Overrides:
orColumnin classAbstractColumnPredicate- Parameters:
predicate- Another predicate on this column- Returns:
- Union predicate on this column
-
cloneWithColumn
Description copied from interface:StarColumnPredicateThis method is required because unfortunately some ColumnPredicate objects are created without a column.We call this method to provide a fake column, then call
StarPredicate.toSql(mondrian.rolap.sql.SqlQuery, StringBuilder).todo: remove this method when
bug MONDRIAN-313andbug MONDRIAN-314are fixed. -
toSql
- Specified by:
toSqlin interfaceStarPredicate- Overrides:
toSqlin classAbstractColumnPredicate
-