Automatic data expiration YCQL
Consider a scenario where you only need the last few values and the older data is not of any value and can be purged. Typically, this requires setting up a separate background job. Using YugabyteDB however, you can set an expiration value for columns using the USING TTL
operator.
Note
TTL-based expiration is only available in YCQL.Setup
Setup
To set up a local universe, refer to Set up a local YugabyteDB universe.Setup
To set up a cluster, refer to Set up a YugabyteDB Aeon cluster.Setup
To set up a universe, refer to Set up a YugabyteDB Anywhere universe.Row-level TTL
Consider a speed metrics tracking system that tracks the data from the speed sensor of many cars.
Create a table and insert data with an example schema as follows:
CREATE KEYSPACE IF NOT EXISTS yugabyte;
USE yugabyte;
CREATE TABLE exp_demo (
ts timestamp,/* time at which the event was generated */
car text, /* name of the car */
speed int, /* speed of your car */
PRIMARY KEY(car, ts)
) WITH CLUSTERING ORDER BY (ts DESC);
INSERT INTO exp_demo(ts,car,speed) VALUES('2023-07-01 10:00:01','car-1',50) USING TTL 10;
INSERT INTO exp_demo(ts,car,speed) VALUES('2023-07-01 10:00:02','car-2',25) USING TTL 15;
INSERT INTO exp_demo(ts,car,speed) VALUES('2023-07-01 10:00:03','car-1',39) USING TTL 15;
INSERT INTO exp_demo(ts,car,speed) VALUES('2023-07-01 10:00:04','car-1',49) USING TTL 20;
INSERT INTO exp_demo(ts,car,speed) VALUES('2023-07-01 10:00:05','car-2', 3) USING TTL 25;
As soon as you insert the data, start selecting all rows over and over. Eventually, you will see all the data disappear.
SELECT * from exp_demo;
Column-level TTL
For more fine-grained expiration, instead of setting the TTL on an entire row, you can set TTL per column. For example, do the following:
-
Add a row.
INSERT INTO exp_demo(ts,car,speed) VALUES('2023-08-01 10:00:01', 'car-5', 50);
-
Fetch the rows.
SELECT * FROM exp_demo WHERE car='car-5';
car | ts | speed -------+---------------------------------+------- car-5 | 2023-08-01 17:00:01.000000+0000 | 50
-
Set an expiration on the speed column of that row as follows:
UPDATE exp_demo USING TTL 5 SET speed=10 WHERE car='car-5' AND ts ='2023-08-01 10:00:01';
-
Wait for five seconds and fetch the row for
car-5
.SELECT * FROM exp_demo WHERE car='car-5';
car | ts | speed -------+---------------------------------+------- car-5 | 2023-08-01 17:00:01.000000+0000 | null
Note that the row is present but the value for the speed
column is null
.
Table-level TTL
Instead of explicitly setting the TTL at the row or column level, you can set a TTL on the table. This also has the benefit of saving space as the TTL value is stored in only one place and not per row or column.
Define table-level TTL using the default_time_to_live property.