InfluxDB如何获取最后记录的值

Ego*_*yev 5 java database influxdb

有一个 Inflix DB 数据库,其中写入了值。如何获取名为“test”的设备的最后记录数据(例如,协议号和时间长)?我试图通过它query,但它只返回一分,尽管数据库中有大约 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;
    }
Run Code Online (Sandbox Code Playgroud)

m.g*_*shi 7

您可以使用以下last功能获取最后一项:

SELECT last(protocol) FROM device [optional: WHERE <your condition>]
Run Code Online (Sandbox Code Playgroud)

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

SELECT * FROM device ORDER BY desc LIMIT 1
Run Code Online (Sandbox Code Playgroud)