-
Notifications
You must be signed in to change notification settings - Fork 332
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: flow compare null values (#5234)
* fix: flow compare null values * fix: fix again ck ty before cmp * chore: rm comment * fix: handle null * chore: typo * docs: update comment * refactor: per review * tests: more sqlness
- Loading branch information
Showing
3 changed files
with
440 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,251 @@ | ||
-- test null handling in flow | ||
-- test null handling in value part of key-value pair | ||
CREATE TABLE requests ( | ||
service_name STRING, | ||
service_ip STRING, | ||
val INT, | ||
ts TIMESTAMP TIME INDEX | ||
); | ||
|
||
Affected Rows: 0 | ||
|
||
CREATE TABLE sum_val_in_reqs ( | ||
sum_val INT64, | ||
ts TIMESTAMP TIME INDEX | ||
); | ||
|
||
Affected Rows: 0 | ||
|
||
CREATE FLOW requests_long_term SINK TO sum_val_in_reqs AS | ||
SELECT | ||
sum(val) as sum_val, | ||
date_bin(INTERVAL '30 seconds', ts) as time_window, | ||
FROM | ||
requests | ||
GROUP BY | ||
time_window; | ||
|
||
Affected Rows: 0 | ||
|
||
INSERT INTO | ||
requests | ||
VALUES | ||
(NULL, "10.0.0.1", NULL, "2024-10-18 19:00:00"), | ||
("svc1", "10.0.0.2", 100, "2024-10-18 19:00:00"), | ||
(NULL, "10.0.0.1", NULL, "2024-10-18 19:00:30"), | ||
("svc1", "10.0.0.2", 200, "2024-10-18 19:00:30"), | ||
(NULL, "10.0.0.1", 300, "2024-10-18 19:01:00"), | ||
(NULL, "10.0.0.2", NULL, "2024-10-18 19:01:01"), | ||
("svc1", "10.0.0.1", 400, "2024-10-18 19:01:30"), | ||
("svc1", "10.0.0.2", 200, "2024-10-18 19:01:31"); | ||
|
||
Affected Rows: 8 | ||
|
||
-- SQLNESS REPLACE (ADMIN\sFLUSH_FLOW\('\w+'\)\s+\|\n\+-+\+\n\|\s+)[0-9]+\s+\| $1 FLOW_FLUSHED | | ||
ADMIN FLUSH_FLOW('requests_long_term'); | ||
|
||
+----------------------------------------+ | ||
| ADMIN FLUSH_FLOW('requests_long_term') | | ||
+----------------------------------------+ | ||
| FLOW_FLUSHED | | ||
+----------------------------------------+ | ||
|
||
SELECT | ||
* | ||
FROM | ||
sum_val_in_reqs; | ||
|
||
+---------+---------------------+ | ||
| sum_val | ts | | ||
+---------+---------------------+ | ||
| 100 | 2024-10-18T19:00:00 | | ||
| 200 | 2024-10-18T19:00:30 | | ||
| 300 | 2024-10-18T19:01:00 | | ||
| 600 | 2024-10-18T19:01:30 | | ||
+---------+---------------------+ | ||
|
||
-- Test if FLOWS table works, but don't care about the result since it vary from runs | ||
SELECT | ||
count(CASE WHEN state_size > 0 THEN 1 ELSE 0 END) as active_flows, | ||
FROM | ||
INFORMATION_SCHEMA.FLOWS; | ||
|
||
+--------------+ | ||
| active_flows | | ||
+--------------+ | ||
| 1 | | ||
+--------------+ | ||
|
||
DROP FLOW requests_long_term; | ||
|
||
Affected Rows: 0 | ||
|
||
DROP TABLE sum_val_in_reqs; | ||
|
||
Affected Rows: 0 | ||
|
||
DROP TABLE requests; | ||
|
||
Affected Rows: 0 | ||
|
||
-- test null handling in key part of key-value pair | ||
CREATE TABLE ngx_access_log ( | ||
client STRING, | ||
country STRING, | ||
access_time TIMESTAMP TIME INDEX | ||
); | ||
|
||
Affected Rows: 0 | ||
|
||
CREATE FLOW calc_ngx_country SINK TO ngx_country AS | ||
SELECT | ||
client, | ||
country as 'country', | ||
count(1) as country_count, | ||
date_bin(INTERVAL '1 hour', access_time) as time_window, | ||
FROM | ||
ngx_access_log | ||
GROUP BY | ||
client, | ||
country, | ||
time_window; | ||
|
||
Affected Rows: 0 | ||
|
||
INSERT INTO | ||
ngx_access_log | ||
VALUES | ||
("cli1", null, 0), | ||
("cli1", null, 0), | ||
("cli2", null, 0), | ||
("cli2", null, 1), | ||
("cli1", "b", 0), | ||
("cli1", "c", 0); | ||
|
||
Affected Rows: 6 | ||
|
||
-- SQLNESS REPLACE (ADMIN\sFLUSH_FLOW\('\w+'\)\s+\|\n\+-+\+\n\|\s+)[0-9]+\s+\| $1 FLOW_FLUSHED | | ||
ADMIN FLUSH_FLOW('calc_ngx_country'); | ||
|
||
+--------------------------------------+ | ||
| ADMIN FLUSH_FLOW('calc_ngx_country') | | ||
+--------------------------------------+ | ||
| FLOW_FLUSHED | | ||
+--------------------------------------+ | ||
|
||
SHOW CREATE TABLE ngx_country; | ||
|
||
+-------------+----------------------------------------------------------------------------------+ | ||
| Table | Create Table | | ||
+-------------+----------------------------------------------------------------------------------+ | ||
| ngx_country | CREATE TABLE IF NOT EXISTS "ngx_country" ( | | ||
| | "ngx_access_log.client" STRING NULL, | | ||
| | "ngx_access_log.country" STRING NULL, | | ||
| | "country_count" BIGINT NULL, | | ||
| | "time_window" TIMESTAMP(3) NULL, | | ||
| | "update_at" TIMESTAMP(3) NULL, | | ||
| | "__ts_placeholder" TIMESTAMP(3) NOT NULL, | | ||
| | TIME INDEX ("__ts_placeholder"), | | ||
| | PRIMARY KEY ("ngx_access_log.client", "ngx_access_log.country", "time_window") | | ||
| | ) | | ||
| | | | ||
| | ENGINE=mito | | ||
| | | | ||
+-------------+----------------------------------------------------------------------------------+ | ||
|
||
SELECT | ||
"ngx_access_log.client", | ||
"ngx_access_log.country", | ||
country_count, | ||
time_window | ||
FROM | ||
ngx_country; | ||
|
||
+-----------------------+------------------------+---------------+---------------------+ | ||
| ngx_access_log.client | ngx_access_log.country | country_count | time_window | | ||
+-----------------------+------------------------+---------------+---------------------+ | ||
| cli1 | | 2 | 1970-01-01T00:00:00 | | ||
| cli1 | b | 1 | 1970-01-01T00:00:00 | | ||
| cli1 | c | 1 | 1970-01-01T00:00:00 | | ||
| cli2 | | 2 | 1970-01-01T00:00:00 | | ||
+-----------------------+------------------------+---------------+---------------------+ | ||
|
||
-- making sure distinct is working | ||
INSERT INTO | ||
ngx_access_log | ||
VALUES | ||
("cli1", "b", 1); | ||
|
||
Affected Rows: 1 | ||
|
||
-- SQLNESS REPLACE (ADMIN\sFLUSH_FLOW\('\w+'\)\s+\|\n\+-+\+\n\|\s+)[0-9]+\s+\| $1 FLOW_FLUSHED | | ||
ADMIN FLUSH_FLOW('calc_ngx_country'); | ||
|
||
+--------------------------------------+ | ||
| ADMIN FLUSH_FLOW('calc_ngx_country') | | ||
+--------------------------------------+ | ||
| FLOW_FLUSHED | | ||
+--------------------------------------+ | ||
|
||
SELECT | ||
"ngx_access_log.client", | ||
"ngx_access_log.country", | ||
country_count, | ||
time_window | ||
FROM | ||
ngx_country; | ||
|
||
+-----------------------+------------------------+---------------+---------------------+ | ||
| ngx_access_log.client | ngx_access_log.country | country_count | time_window | | ||
+-----------------------+------------------------+---------------+---------------------+ | ||
| cli1 | | 2 | 1970-01-01T00:00:00 | | ||
| cli1 | b | 2 | 1970-01-01T00:00:00 | | ||
| cli1 | c | 1 | 1970-01-01T00:00:00 | | ||
| cli2 | | 2 | 1970-01-01T00:00:00 | | ||
+-----------------------+------------------------+---------------+---------------------+ | ||
|
||
INSERT INTO | ||
ngx_access_log | ||
VALUES | ||
("cli1", "c", 2); | ||
|
||
Affected Rows: 1 | ||
|
||
-- SQLNESS REPLACE (ADMIN\sFLUSH_FLOW\('\w+'\)\s+\|\n\+-+\+\n\|\s+)[0-9]+\s+\| $1 FLOW_FLUSHED | | ||
ADMIN FLUSH_FLOW('calc_ngx_country'); | ||
|
||
+--------------------------------------+ | ||
| ADMIN FLUSH_FLOW('calc_ngx_country') | | ||
+--------------------------------------+ | ||
| FLOW_FLUSHED | | ||
+--------------------------------------+ | ||
|
||
SELECT | ||
"ngx_access_log.client", | ||
"ngx_access_log.country", | ||
country_count, | ||
time_window | ||
FROM | ||
ngx_country; | ||
|
||
+-----------------------+------------------------+---------------+---------------------+ | ||
| ngx_access_log.client | ngx_access_log.country | country_count | time_window | | ||
+-----------------------+------------------------+---------------+---------------------+ | ||
| cli1 | | 2 | 1970-01-01T00:00:00 | | ||
| cli1 | b | 2 | 1970-01-01T00:00:00 | | ||
| cli1 | c | 2 | 1970-01-01T00:00:00 | | ||
| cli2 | | 2 | 1970-01-01T00:00:00 | | ||
+-----------------------+------------------------+---------------+---------------------+ | ||
|
||
DROP FLOW calc_ngx_country; | ||
|
||
Affected Rows: 0 | ||
|
||
DROP TABLE ngx_access_log; | ||
|
||
Affected Rows: 0 | ||
|
||
DROP TABLE ngx_country; | ||
|
||
Affected Rows: 0 | ||
|
Oops, something went wrong.