This is an automated email from the ASF dual-hosted git repository.
qiaojialin pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/iotdb.git
The following commit(s) were added to refs/heads/master by this push:
new 0b66a04019 Skip checking duplicated measurements in one write request
(#8178)
0b66a04019 is described below
commit 0b66a0401916708dae562651c15b794c194dd145
Author: Haonan <[email protected]>
AuthorDate: Sat Nov 26 09:03:23 2022 +0800
Skip checking duplicated measurements in one write request (#8178)
---
.../org/apache/iotdb/commons/utils/PathUtils.java | 39 +++++++++++++++++++++-
1 file changed, 38 insertions(+), 1 deletion(-)
diff --git
a/node-commons/src/main/java/org/apache/iotdb/commons/utils/PathUtils.java
b/node-commons/src/main/java/org/apache/iotdb/commons/utils/PathUtils.java
index 658df351ef..3837424864 100644
--- a/node-commons/src/main/java/org/apache/iotdb/commons/utils/PathUtils.java
+++ b/node-commons/src/main/java/org/apache/iotdb/commons/utils/PathUtils.java
@@ -26,7 +26,9 @@ import org.apache.iotdb.tsfile.exception.PathParseException;
import org.apache.iotdb.tsfile.read.common.parser.PathNodesGenerator;
import org.apache.iotdb.tsfile.read.common.parser.PathVisitor;
+import java.util.HashSet;
import java.util.List;
+import java.util.Set;
public class PathUtils {
@@ -63,8 +65,43 @@ public class PathUtils {
if (measurementLists == null) {
return;
}
+ // use set to skip checking duplicated measurements
+ Set<String> measurementSet = new HashSet<>();
for (List<String> measurements : measurementLists) {
- isLegalSingleMeasurements(measurements);
+ checkLegalSingleMeasurementsAndSkipDuplicate(measurements,
measurementSet);
+ }
+ }
+
+ /**
+ * check whether measurement is legal according to syntax convention
measurement can only be a
+ * single node name, use set to skip checking duplicated measurements
+ */
+ public static void checkLegalSingleMeasurementsAndSkipDuplicate(
+ List<String> measurements, Set<String> measurementSet) throws
MetadataException {
+ if (measurements == null) {
+ return;
+ }
+ for (String measurement : measurements) {
+ if (measurement == null) {
+ continue;
+ }
+ if (measurementSet.contains(measurement)) {
+ continue;
+ }
+ measurementSet.add(measurement);
+ if (measurement.startsWith(TsFileConstant.BACK_QUOTE_STRING)
+ && measurement.endsWith(TsFileConstant.BACK_QUOTE_STRING)) {
+ if (checkBackQuotes(measurement.substring(1, measurement.length() -
1))) {
+ continue;
+ } else {
+ throw new IllegalPathException(measurement);
+ }
+ }
+ if (IoTDBConstant.reservedWords.contains(measurement.toUpperCase())
+ || isRealNumber(measurement)
+ || !TsFileConstant.NODE_NAME_PATTERN.matcher(measurement).matches())
{
+ throw new IllegalPathException(measurement);
+ }
}
}