-
Notifications
You must be signed in to change notification settings - Fork 55
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
move examples module and change common-api to common
- Loading branch information
1 parent
244cd0d
commit 99fa36b
Showing
25 changed files
with
1,040 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
<?xml version="1.0" encoding="UTF-8"?> | ||
<!-- | ||
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. | ||
--> | ||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> | ||
<modelVersion>4.0.0</modelVersion> | ||
<parent> | ||
<groupId>org.apache.tsfile</groupId> | ||
<artifactId>tsfile-parent</artifactId> | ||
<version>1.0.0-SNAPSHOT</version> | ||
</parent> | ||
<artifactId>tsfile-examples</artifactId> | ||
<name>TSFile: Examples</name> | ||
<dependencies> | ||
<dependency> | ||
<groupId>org.apache.tsfile</groupId> | ||
<artifactId>tsfile</artifactId> | ||
<version>1.0.0-SNAPSHOT</version> | ||
</dependency> | ||
</dependencies> | ||
</project> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
<!-- | ||
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. | ||
--> | ||
|
||
# Function | ||
``` | ||
The example is to show how to write and read a TsFile File. | ||
``` | ||
# Usage | ||
## Dependencies with Maven | ||
|
||
``` | ||
<dependencies> | ||
<dependency> | ||
<groupId>org.apache.tsfile</groupId> | ||
<artifactId>tsfile</artifactId> | ||
<version>1.0.0-SNAPSHOT</version> | ||
</dependency> | ||
</dependencies> | ||
``` | ||
|
||
|
||
## Run TsFileWrite.java | ||
|
||
|
||
This class is to show how to write a TsFile. It provided two ways: | ||
|
||
The first one is using a JSON string for measurement(s). The JSON string is an array of JSON | ||
objects(schema). The object must include the *measurement_id*, *datatype*, *encoding*, and | ||
*compressor*. | ||
|
||
An example JSON string is provided in the comments in | ||
the method | ||
|
||
public static void tsFileWriteWithJson() throws IOException,WriteProcessException | ||
It uses this interface | ||
|
||
public void addMeasurementByJson(JSONObject measurement) throws WriteProcessException | ||
An alternative way is to add these measurements directly(manually) by the second interface: | ||
|
||
public void addMeasurement(MeasurementSchema measurementSchema) throws WriteProcessException | ||
|
||
The method | ||
|
||
public static void tsFileWriteDirect() throws IOException,WriteProcessException | ||
shows how to use that interface. | ||
|
||
Note that the measurements in the two methods are the same therefore there output TsFile should also be identical. | ||
|
||
|
||
|
||
## Run TsFileRead.java | ||
|
||
This class is to show how to read TsFile file named "testDirect.tsfile". | ||
|
||
The TsFile file "testDirect.tsfile" is generated from class TsFileWrite. | ||
|
||
It generates the same TsFile(testDirect.tsfile and testWithJson.tsfile) file by two different ways | ||
|
||
Run TsFileWrite to generate the testDirect.tsfile first | ||
|
||
## Run TsFileSequenceRead.java | ||
|
||
This class is to show the structure of a TsFile. | ||
|
||
### Notice | ||
For detail, please refer to https://github.com/apache/iotdb/blob/master/tsfile/README.md. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
/* | ||
* 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.tsfile; | ||
|
||
public class Constant { | ||
|
||
private Constant() {} | ||
|
||
static final String SENSOR_1 = "sensor_1"; | ||
static final String SENSOR_2 = "sensor_2"; | ||
static final String SENSOR_3 = "sensor_3"; | ||
|
||
static final String DEVICE_PREFIX = "device_"; | ||
static final String DEVICE_1 = "root.sg.device_1"; | ||
static final String DEVICE_2 = "root.sg.device_2"; | ||
} |
123 changes: 123 additions & 0 deletions
123
examples/src/main/java/org/apache/tsfile/TsFileForceAppendWrite.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,123 @@ | ||
/* | ||
* 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.tsfile; | ||
|
||
import org.apache.iotdb.tsfile.file.metadata.enums.TSDataType; | ||
import org.apache.iotdb.tsfile.file.metadata.enums.TSEncoding; | ||
import org.apache.iotdb.tsfile.fileSystem.FSFactoryProducer; | ||
import org.apache.iotdb.tsfile.read.common.Path; | ||
import org.apache.iotdb.tsfile.write.TsFileWriter; | ||
import org.apache.iotdb.tsfile.write.record.TSRecord; | ||
import org.apache.iotdb.tsfile.write.record.datapoint.DataPoint; | ||
import org.apache.iotdb.tsfile.write.record.datapoint.LongDataPoint; | ||
import org.apache.iotdb.tsfile.write.schema.MeasurementSchema; | ||
import org.apache.iotdb.tsfile.write.writer.ForceAppendTsFileWriter; | ||
import org.slf4j.Logger; | ||
import org.slf4j.LoggerFactory; | ||
|
||
import java.io.File; | ||
import java.io.IOException; | ||
import java.nio.file.Files; | ||
|
||
public class TsFileForceAppendWrite { | ||
|
||
private static final Logger LOGGER = LoggerFactory.getLogger(TsFileForceAppendWrite.class); | ||
|
||
public static void main(String[] args) throws IOException { | ||
String path = "test.tsfile"; | ||
File f = FSFactoryProducer.getFSFactory().getFile(path); | ||
if (f.exists()) { | ||
Files.delete(f.toPath()); | ||
} | ||
|
||
try (TsFileWriter tsFileWriter = new TsFileWriter(f)) { | ||
|
||
// add measurements into file schema | ||
for (int i = 0; i < 4; i++) { | ||
tsFileWriter.registerTimeseries( | ||
new Path(Constant.DEVICE_PREFIX + i), | ||
new MeasurementSchema(Constant.SENSOR_1, TSDataType.INT64, TSEncoding.RLE)); | ||
tsFileWriter.registerTimeseries( | ||
new Path(Constant.DEVICE_PREFIX + i), | ||
new MeasurementSchema(Constant.SENSOR_2, TSDataType.INT64, TSEncoding.RLE)); | ||
tsFileWriter.registerTimeseries( | ||
new Path(Constant.DEVICE_PREFIX + i), | ||
new MeasurementSchema(Constant.SENSOR_3, TSDataType.INT64, TSEncoding.RLE)); | ||
} | ||
|
||
// construct TSRecord | ||
for (int i = 0; i < 100; i++) { | ||
TSRecord tsRecord = new TSRecord(i, Constant.DEVICE_PREFIX + (i % 4)); | ||
DataPoint dPoint1 = new LongDataPoint(Constant.SENSOR_1, i); | ||
DataPoint dPoint2 = new LongDataPoint(Constant.SENSOR_2, i); | ||
DataPoint dPoint3 = new LongDataPoint(Constant.SENSOR_3, i); | ||
tsRecord.addTuple(dPoint1); | ||
tsRecord.addTuple(dPoint2); | ||
tsRecord.addTuple(dPoint3); | ||
|
||
// write TSRecord | ||
tsFileWriter.write(tsRecord); | ||
} | ||
} catch (Exception e) { | ||
LOGGER.error("meet error in TsFileWrite ", e); | ||
} | ||
|
||
// open the closed file with ForceAppendTsFileWriter | ||
|
||
try (ForceAppendTsFileWriter fwriter = new ForceAppendTsFileWriter(f)) { | ||
fwriter.doTruncate(); | ||
write(fwriter); | ||
} catch (Exception e) { | ||
LOGGER.error("ForceAppendTsFileWriter truncate or write error ", e); | ||
} | ||
} | ||
|
||
private static void write(ForceAppendTsFileWriter fwriter) { | ||
try (TsFileWriter tsFileWriter1 = new TsFileWriter(fwriter)) { | ||
// add measurements into file schema | ||
for (int i = 0; i < 4; i++) { | ||
tsFileWriter1.registerTimeseries( | ||
new Path(Constant.DEVICE_PREFIX + i), | ||
new MeasurementSchema(Constant.SENSOR_1, TSDataType.INT64, TSEncoding.RLE)); | ||
tsFileWriter1.registerTimeseries( | ||
new Path(Constant.DEVICE_PREFIX + i), | ||
new MeasurementSchema(Constant.SENSOR_2, TSDataType.INT64, TSEncoding.RLE)); | ||
tsFileWriter1.registerTimeseries( | ||
new Path(Constant.DEVICE_PREFIX + i), | ||
new MeasurementSchema(Constant.SENSOR_3, TSDataType.INT64, TSEncoding.RLE)); | ||
} | ||
// construct TSRecord | ||
for (int i = 100; i < 120; i++) { | ||
TSRecord tsRecord = new TSRecord(i, Constant.DEVICE_PREFIX + (i % 4)); | ||
DataPoint dPoint1 = new LongDataPoint(Constant.SENSOR_1, i); | ||
DataPoint dPoint2 = new LongDataPoint(Constant.SENSOR_2, i); | ||
DataPoint dPoint3 = new LongDataPoint(Constant.SENSOR_3, i); | ||
tsRecord.addTuple(dPoint1); | ||
tsRecord.addTuple(dPoint2); | ||
tsRecord.addTuple(dPoint3); | ||
|
||
// write TSRecord | ||
tsFileWriter1.write(tsRecord); | ||
} | ||
} catch (Exception e) { | ||
LOGGER.error("meet error in TsFileWrite ", e); | ||
} | ||
} | ||
} |
105 changes: 105 additions & 0 deletions
105
examples/src/main/java/org/apache/tsfile/TsFileRead.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,105 @@ | ||
/* | ||
* 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.tsfile; | ||
|
||
import org.apache.iotdb.tsfile.read.TsFileReader; | ||
import org.apache.iotdb.tsfile.read.TsFileSequenceReader; | ||
import org.apache.iotdb.tsfile.read.common.Path; | ||
import org.apache.iotdb.tsfile.read.expression.IExpression; | ||
import org.apache.iotdb.tsfile.read.expression.QueryExpression; | ||
import org.apache.iotdb.tsfile.read.expression.impl.BinaryExpression; | ||
import org.apache.iotdb.tsfile.read.expression.impl.GlobalTimeExpression; | ||
import org.apache.iotdb.tsfile.read.expression.impl.SingleSeriesExpression; | ||
import org.apache.iotdb.tsfile.read.filter.factory.TimeFilterApi; | ||
import org.apache.iotdb.tsfile.read.filter.factory.ValueFilterApi; | ||
import org.apache.iotdb.tsfile.read.query.dataset.QueryDataSet; | ||
import org.slf4j.Logger; | ||
import org.slf4j.LoggerFactory; | ||
|
||
import java.io.IOException; | ||
import java.util.ArrayList; | ||
|
||
import static org.apache.tsfile.Constant.DEVICE_1; | ||
import static org.apache.tsfile.Constant.SENSOR_1; | ||
import static org.apache.tsfile.Constant.SENSOR_2; | ||
import static org.apache.tsfile.Constant.SENSOR_3; | ||
|
||
/** | ||
* The class is to show how to read TsFile file named "test.tsfile". The TsFile file "test.tsfile" | ||
* is generated from class TsFileWriteWithTSRecord or TsFileWriteWithTablet. Run | ||
* TsFileWriteWithTSRecord or TsFileWriteWithTablet to generate the test.tsfile first | ||
*/ | ||
public class TsFileRead { | ||
|
||
private static final Logger LOGGER = LoggerFactory.getLogger(TsFileRead.class); | ||
|
||
private static void queryAndPrint( | ||
ArrayList<Path> paths, TsFileReader readTsFile, IExpression statement) throws IOException { | ||
QueryExpression queryExpression = QueryExpression.create(paths, statement); | ||
QueryDataSet queryDataSet = readTsFile.query(queryExpression); | ||
while (queryDataSet.hasNext()) { | ||
String next = queryDataSet.next().toString(); | ||
LOGGER.info(next); | ||
} | ||
LOGGER.info("----------------"); | ||
} | ||
|
||
public static void main(String[] args) throws IOException { | ||
|
||
// file path | ||
String path = "test.tsfile"; | ||
|
||
// create reader and get the readTsFile interface | ||
try (TsFileSequenceReader reader = new TsFileSequenceReader(path); | ||
TsFileReader readTsFile = new TsFileReader(reader)) { | ||
|
||
// use these paths(all measurements) for all the queries | ||
ArrayList<Path> paths = new ArrayList<>(); | ||
paths.add(new Path(DEVICE_1, SENSOR_1, true)); | ||
paths.add(new Path(DEVICE_1, SENSOR_2, true)); | ||
paths.add(new Path(DEVICE_1, SENSOR_3, true)); | ||
|
||
// no filter, should select 1 2 3 4 6 7 8 | ||
queryAndPrint(paths, readTsFile, null); | ||
|
||
// time filter : 4 <= time <= 10, should select 4 6 7 8 | ||
IExpression timeFilter = | ||
BinaryExpression.and( | ||
new GlobalTimeExpression(TimeFilterApi.gtEq(4L)), | ||
new GlobalTimeExpression(TimeFilterApi.ltEq(10L))); | ||
queryAndPrint(paths, readTsFile, timeFilter); | ||
|
||
// value filter : device_1.sensor_2 <= 20, should select 1 2 4 6 7 | ||
IExpression valueFilter = | ||
new SingleSeriesExpression(new Path(DEVICE_1, SENSOR_2, true), ValueFilterApi.ltEq(20L)); | ||
queryAndPrint(paths, readTsFile, valueFilter); | ||
|
||
// time filter : 4 <= time <= 10, value filter : device_1.sensor_3 >= 20, should select 4 7 8 | ||
timeFilter = | ||
BinaryExpression.and( | ||
new GlobalTimeExpression(TimeFilterApi.gtEq(4L)), | ||
new GlobalTimeExpression(TimeFilterApi.ltEq(10L))); | ||
valueFilter = | ||
new SingleSeriesExpression(new Path(DEVICE_1, SENSOR_3, true), ValueFilterApi.gtEq(20L)); | ||
IExpression finalFilter = BinaryExpression.and(timeFilter, valueFilter); | ||
queryAndPrint(paths, readTsFile, finalFilter); | ||
} | ||
} | ||
} |
Oops, something went wrong.