com.infomaximum.database.engine.RangeIterator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of rdao Show documentation
Show all versions of rdao Show documentation
Library for creating a light cluster
The newest version!
package com.infomaximum.database.engine;
import com.infomaximum.database.domainobject.filter.RangeFilter;
import com.infomaximum.database.domainobject.filter.SortDirection;
import com.infomaximum.database.exception.DatabaseException;
import com.infomaximum.database.provider.DBDataReader;
import com.infomaximum.database.provider.DBIterator;
import com.infomaximum.database.provider.KeyPattern;
import com.infomaximum.database.provider.KeyValue;
import com.infomaximum.database.schema.dbstruct.DBBaseIntervalIndex;
import com.infomaximum.database.schema.dbstruct.DBTable;
import com.infomaximum.database.utils.RangeIndexUtils;
import com.infomaximum.database.utils.key.RangeIndexKey;
import java.util.HashSet;
import java.util.Set;
public class RangeIterator extends BaseIntervalRecordIterator {
private Set processedIds/* = null*/; // не нужно инициализировать, т.к. matchKey вызывается из конструктора базового класса
public RangeIterator(DBTable table, RangeFilter filter, DBDataReader dataReader) {
super(table, filter, SortDirection.ASC, dataReader);
}
@Override
DBBaseIntervalIndex getIndex(RangeFilter filter, DBTable table) {
return table.getIndex(filter);
}
@Override
KeyValue seek(DBIterator indexIterator, KeyPattern pattern) throws DatabaseException {
return RangeIndexUtils.seek(indexIterator, pattern, filterBeginValue);
}
@Override
int matchKey(long id, byte[] key) {
long indexedValue = RangeIndexKey.unpackIndexedValue(key);
if (indexedValue > filterEndValue) {
return KeyPattern.MATCH_RESULT_UNSUCCESS;
} else if (indexedValue == filterEndValue) {
if (filterBeginValue != filterEndValue) {
return KeyPattern.MATCH_RESULT_UNSUCCESS;
}
return RangeIndexKey.unpackType(key) == RangeIndexKey.Type.DOT ? KeyPattern.MATCH_RESULT_SUCCESS : KeyPattern.MATCH_RESULT_CONTINUE;
}
if (processedIds != null && processedIds.contains(id)) {
if (RangeIndexKey.unpackType(key) == RangeIndexKey.Type.END) {
processedIds.remove(id);
}
return KeyPattern.MATCH_RESULT_CONTINUE;
}
if (RangeIndexKey.unpackType(key) == RangeIndexKey.Type.BEGIN) {
if (processedIds == null) {
processedIds = new HashSet<>();
}
processedIds.add(id);
}
return KeyPattern.MATCH_RESULT_SUCCESS;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy