org.apache.iotdb.db.query.context.QueryContext Maven / Gradle / Ivy
/*
* 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.iotdb.db.query.context;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import org.apache.iotdb.db.engine.modification.Modification;
import org.apache.iotdb.db.engine.modification.ModificationFile;
import org.apache.iotdb.db.metadata.PartialPath;
import org.apache.iotdb.tsfile.file.metadata.ChunkMetadata;
/**
* QueryContext contains the shared information with in a query.
*/
public class QueryContext {
/**
* The outer key is the path of a ModificationFile, the inner key in the name of a timeseries and
* the value is the Modifications of a timeseries in this file.
*/
private Map>> filePathModCache = new ConcurrentHashMap<>();
/**
* The key is the path of a ModificationFile and the value is all Modifications in this file. We
* use this field because each call of Modification.getModifications() return a copy of the
* Modifications, and we do not want it to create multiple copies within a query.
*/
private Map> fileModCache = new HashMap<>();
private long queryId;
private long queryTimeLowerBound = Long.MIN_VALUE;
public QueryContext() {
}
public QueryContext(long queryId) {
this.queryId = queryId;
}
/**
* Find the modifications of timeseries 'path' in 'modFile'. If they are not in the cache, read
* them from 'modFile' and put then into the cache.
*/
public List getPathModifications(ModificationFile modFile, PartialPath path) {
Map> fileModifications =
filePathModCache.computeIfAbsent(modFile.getFilePath(), k -> new ConcurrentHashMap<>());
return fileModifications.computeIfAbsent(path.getFullPath(), k -> {
List allModifications = fileModCache.get(modFile.getFilePath());
if (allModifications == null) {
allModifications = (List) modFile.getModifications();
fileModCache.put(modFile.getFilePath(), allModifications);
}
List finalPathModifications = new ArrayList<>();
if (!allModifications.isEmpty()) {
allModifications.forEach(modification -> {
if (modification.getPath().matchFullPath(path)) {
finalPathModifications.add(modification);
}
});
}
return finalPathModifications;
});
}
public long getQueryId() {
return queryId;
}
public long getQueryTimeLowerBound() {
return queryTimeLowerBound;
}
public void setQueryTimeLowerBound(long queryTimeLowerBound) {
this.queryTimeLowerBound = queryTimeLowerBound;
}
public boolean chunkNotSatisfy(ChunkMetadata chunkMetaData) {
return chunkMetaData.getEndTime() < queryTimeLowerBound;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy