mirror of
https://github.com/GreptimeTeam/greptimedb.git
synced 2026-01-06 13:22:57 +00:00
* feat: eable range expr nest * fix: change range expr rewrite format * chore: organize range query tests * chore: change range expr name(e.g. MAX(v) RANGE 5s FILL 6) * chore: add range query test * chore: fix code advice * chore: fix ca
55 lines
2.2 KiB
Plaintext
55 lines
2.2 KiB
Plaintext
CREATE TABLE host (
|
|
ts timestamp(3) time index,
|
|
host STRING PRIMARY KEY,
|
|
val BIGINT,
|
|
);
|
|
|
|
Affected Rows: 0
|
|
|
|
INSERT INTO TABLE host VALUES
|
|
(0, 'host1', 0),
|
|
(5000, 'host1', null),
|
|
(10000, 'host1', 1),
|
|
(15000, 'host1', null),
|
|
(20000, 'host1', 2),
|
|
(0, 'host2', 3),
|
|
(5000, 'host2', null),
|
|
(10000, 'host2', 4),
|
|
(15000, 'host2', null),
|
|
(20000, 'host2', 5);
|
|
|
|
Affected Rows: 10
|
|
|
|
-- Test by calculate
|
|
SELECT ts, length(host), max(val) RANGE '5s' FROM host ALIGN '20s' BY (length(host)) ORDER BY ts;
|
|
|
|
+---------------------+-----------------------------+----------------------------------+
|
|
| ts | character_length(host.host) | MAX(host.val) RANGE 5s FILL NULL |
|
|
+---------------------+-----------------------------+----------------------------------+
|
|
| 1970-01-01T00:00:00 | 5 | 3 |
|
|
| 1970-01-01T00:00:20 | 5 | 5 |
|
|
+---------------------+-----------------------------+----------------------------------+
|
|
|
|
SELECT ts, max(val) RANGE '5s' FROM host ALIGN '20s' BY (2) ORDER BY ts;
|
|
|
|
+---------------------+----------------------------------+
|
|
| ts | MAX(host.val) RANGE 5s FILL NULL |
|
|
+---------------------+----------------------------------+
|
|
| 1970-01-01T00:00:00 | 3 |
|
|
| 1970-01-01T00:00:20 | 5 |
|
|
+---------------------+----------------------------------+
|
|
|
|
SELECT ts, CAST(length(host) as INT64) + 2, max(val) RANGE '5s' FROM host ALIGN '20s' BY (CAST(length(host) as INT64) + 2) ORDER BY ts;
|
|
|
|
+---------------------+----------------------------------------+----------------------------------+
|
|
| ts | character_length(host.host) + Int64(2) | MAX(host.val) RANGE 5s FILL NULL |
|
|
+---------------------+----------------------------------------+----------------------------------+
|
|
| 1970-01-01T00:00:00 | 7 | 3 |
|
|
| 1970-01-01T00:00:20 | 7 | 5 |
|
|
+---------------------+----------------------------------------+----------------------------------+
|
|
|
|
DROP TABLE host;
|
|
|
|
Affected Rows: 0
|
|
|