blob: abf89e158a4c311d7dbef6e9c3f6eda33875fd5b [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.ignite.cache.query;
import javax.cache.Cache;
import org.apache.ignite.IgniteCache;
import org.apache.ignite.internal.util.typedef.internal.S;
import org.apache.ignite.lang.IgniteBiPredicate;
import org.jetbrains.annotations.Nullable;
/**
* Scan query over cache entries. Will accept all the entries if no predicate was set.
*
* @see IgniteCache#query(Query)
*/
public final class ScanQuery<K, V> extends Query<Cache.Entry<K, V>> {
/** */
private static final long serialVersionUID = 0L;
/** */
private IgniteBiPredicate<K, V> filter;
/** */
private Integer part;
/**
* Create scan query returning all entries.
*/
public ScanQuery() {
this(null, null);
}
/**
* Creates partition scan query returning all entries for given partition.
*
* @param part Partition.
*/
public ScanQuery(int part) {
this(part, null);
}
/**
* Create scan query with filter.
*
* @param filter Filter. If {@code null} then all entries will be returned.
*/
public ScanQuery(@Nullable IgniteBiPredicate<K, V> filter) {
this(null, filter);
}
/**
* Create scan query with filter.
*
* @param part Partition.
* @param filter Filter. If {@code null} then all entries will be returned.
*/
public ScanQuery(@Nullable Integer part, @Nullable IgniteBiPredicate<K, V> filter) {
setPartition(part);
setFilter(filter);
}
/**
* Gets filter.
*
* @return Filter.
*/
public IgniteBiPredicate<K, V> getFilter() {
return filter;
}
/**
* Sets filter.
*
* @param filter Filter. If {@code null} then all entries will be returned.
* @return {@code this} for chaining.
*/
public ScanQuery<K, V> setFilter(@Nullable IgniteBiPredicate<K, V> filter) {
this.filter = filter;
return this;
}
/**
* Sets partition number over which this query should iterate. If {@code null}, query will iterate over
* all partitions in the cache. Must be in the range [0, N) where N is partition number in the cache.
*
* @param part Partition number over which this query should iterate.
* @return {@code this} for chaining.
*/
public ScanQuery<K, V> setPartition(@Nullable Integer part) {
this.part = part;
return this;
}
/**
* Gets partition number over which this query should iterate. Will return {@code null} if partition was not
* set. In this case query will iterate over all partitions in the cache.
*
* @return Partition number or {@code null}.
*/
@Nullable public Integer getPartition() {
return part;
}
/** {@inheritDoc} */
@Override public ScanQuery<K, V> setPageSize(int pageSize) {
return (ScanQuery<K, V>)super.setPageSize(pageSize);
}
/** {@inheritDoc} */
@Override public ScanQuery<K, V> setLocal(boolean loc) {
return (ScanQuery<K, V>)super.setLocal(loc);
}
/** {@inheritDoc} */
@Override public String toString() {
return S.toString(ScanQuery.class, this);
}
}