Chunks are constrained by a start and end time and the start time is always before the end time. A chunk is dropped if its end time is older than the older_than timestamp or, if newer_than is given, its start time is newer than the newer_than timestamp.

    Note that, because chunks are removed if and only if their time range falls fully before (or after) the specified timestamp, the remaining data may still contain timestamps that are before (or after) the specified one.

    Chunks can only be dropped based on their time intervals. They cannot be dropped based on a space partition.

    NameTypeDescription
    newer_thanINTERVALSpecification of cut-off point where any full chunks newer than this timestamp should be removed.
    verboseBOOLEANSetting to true displays messages about the progress of the reorder command. Defaults to false.

    The older_than and newer_than parameters can be specified in two ways:

    • timestamp, date, or integer type: The cut-off point is explicitly given as a TIMESTAMP / / DATE or as a SMALLINT / INT / BIGINT. The choice of timestamp or integer must follow the type of the hypertable’s time column.

    warning

    When using just an interval type, the function assumes that you are removing things in the past. If you want to remove data in the future, for example to delete erroneous entries, use a timestamp.

    When both arguments are used, the function returns the intersection of the resulting two ranges. For example, specifying newer_than => 4 months and older_than => 3 months drops all full chunks that are between 3 and 4 months old. Similarly, specifying newer_than => '2017-01-01' and older_than => '2017-02-01' drops all full chunks between ‘2017-01-01’ and ‘2017-02-01’. Specifying parameters that do not result in an overlapping intersection between two ranges results in an error.

    Drop all chunks from hypertable conditions older than 3 months:

    1. drop_chunks
    2. ----------------------------------------
    3. _timescaledb_internal._hyper_3_5_chunk
    4. _timescaledb_internal._hyper_3_6_chunk
    5. _timescaledb_internal._hyper_3_7_chunk
    6. _timescaledb_internal._hyper_3_9_chunk
    7. (5 rows)

    Drop all chunks more than 3 months in the future from hypertable conditions. This is useful for correcting data ingested with incorrect clocks:

    Drop all chunks from hypertable conditions before 2017:

    1. SELECT drop_chunks('conditions', '2017-01-01'::date);

    Drop all chunks from hypertable conditions before 2017, where time column is given in milliseconds from the UNIX epoch:

    Drop all chunks older than 3 months ago and newer than 4 months ago from hypertable conditions:

    1. SELECT drop_chunks('conditions', older_than => INTERVAL '3 months', newer_than => INTERVAL '4 months')