删除数据

    在 JAVA 编程环境中,您可以使用 JDBC API 单条或批量执行 DELETE 语句。

    以测控 ln 集团为例,存在这样的使用场景:

    wf02 子站的 wt02 设备在 2017-11-01 16:26:00 之前的供电状态出现多段错误,且无法分析其正确数据,错误数据影响了与其他设备的关联分析。此时,需要将此时间段前的数据删除。进行此操作的 SQL 语句为:

    IoTDB 支持删除一个时间序列任何一个时间范围内的所有时序点,用户可以使用以下 SQL 语句指定需要删除的时间范围:

    需要注意,当前的删除语句不支持 where 子句后的时间范围为多个由 OR 连接成的时间区间。如下删除语句将会解析出错:

    1. delete from root.ln.wf02.wt02.status where time > 4 or time < 0
    2. expressions like : time > XXX, time <= XXX, or two atomic expressions connected by 'AND'

    如果 delete 语句中未指定 where 子句,则会删除时间序列中的所有数据。

    需要注意的是,当删除的路径不存在时,IoTDB 不会提示路径不存在,而是显示执行成功,因为 SQL 是一种声明式的编程方式,除非是语法错误、权限不足等,否则都不认为是错误,如下所示。

    您可以通过如下语句来删除某一个存储组下的指定时间分区:

      上例中的 0,1,2 为待删除时间分区的 id,您可以通过查看 IoTDB 的数据文件夹找到它,或者可以通过计算(向下取整), 手动地将一个时间戳转换为对应的 id,其中的partitionInterval可以在 IoTDB 的配置文件中找到(如果您使用的版本支持时间分区)。