在 pom.xml 的 dependencies中添加以下内容
<dependency> <groupId>org.apache.tsfile</groupId> <artifactId>tsfile</artifactId> <version>1.1.0</version> </dependency>
File f = new File("test.tsfile"); TsFileWriter tsFileWriter = new TsFileWriter(f);
List<MeasurementSchema> schema1 = new ArrayList<>(); schema1.add(new MeasurementSchema("电压", TSDataType.FLOAT)); schema1.add(new MeasurementSchema("电流", TSDataType.FLOAT)); tsFileWriter.registerTimeseries(new Path("太阳能板1"), schema1); List<MeasurementSchema> schema2 = new ArrayList<>(); schema2.add(new MeasurementSchema("电压", TSDataType.FLOAT)); schema2.add(new MeasurementSchema("电流", TSDataType.FLOAT)); schema2.add(new MeasurementSchema("风速", TSDataType.FLOAT)); tsFileWriter.registerTimeseries(new Path("风机1"), schema2);
TSRecord tsRecord = new TSRecord(1, "太阳能板1"); tsRecord.addTuple(DataPoint.getDataPoint(TSDataType.FLOAT, "电压", 1.1f)); tsRecord.addTuple(DataPoint.getDataPoint(TSDataType.FLOAT, "电流", 2.2f)); tsFileWriter.write(tsRecord);
tsFileWriter.close();
TsFileSequenceReader reader = new TsFileSequenceReader(path); TsFileReader tsFileReader = new TsFileReader(reader);
ArrayList<Path> paths = new ArrayList<>(); paths.add(new Path("太阳能板1", "电压",true)); paths.add(new Path("太阳能板1", "电流",true)); IExpression timeFilter = BinaryExpression.and( new GlobalTimeExpression(TimeFilterApi.gtEq(4L)), new GlobalTimeExpression(TimeFilterApi.ltEq(10L))); QueryExpression queryExpression = QueryExpression.create(paths, timeFilter);
QueryDataSet queryDataSet = tsFileReader.query(queryExpression); while (queryDataSet.hasNext()) { queryDataSet.next(); }
tsFileReader.close();