InfluxDB如何获取最后记录的值

InfluxDB how to get the last recorded values

有一个写入值的 Inflix DB 数据库。如何获取名为 "test" 的设备的最后记录数据(例如,协议号和时间)?我试图通过 query 得到它,但它 returns 只有一个点,虽然数据库中有大约 40 个。

下面是示例代码。

public static long getTime( String devName ) {

        InfluxDB influxDB = InfluxDBFactory.connect("http://10.10.1.72:8086");
        String sql = "select time, protocol from device";
        Query query = new Query( sql, dbName );
        QueryResult result = influxDB.query(query);

        Series series = result.getResults().get(0).getSeries().get(0);

        //long time = (long)(double)series.getValues().get(0).get(0);
        System.out.println(series.getColumns().get(0) + "=" + series.getValues().get(0).get(0) + " " + series.getValues().get(0).get(0).getClass().getName());
        System.out.println(series.getColumns().get(1) + "=" + series.getValues().get(0).get(1) + " " + series.getValues().get(0).get(1).getClass().getName());
        return 0;
    }

您可以使用 last 函数获取最后一项:

SELECT last(protocol) FROM device [optional: WHERE <your condition>]

或者你可以使用LIMIT关键字(注意,我们应该使用降序):

SELECT * FROM device ORDER BY desc LIMIT 1