From 2983aff08031b417037916920dfc577d64c58354 Mon Sep 17 00:00:00 2001 From: Lukasz Soszynski Date: Fri, 25 Oct 2024 12:55:16 +0200 Subject: [PATCH 1/2] Fillnull command documentation Signed-off-by: Lukasz Soszynski --- docs/ppl-lang/ppl-fillnull-command.md | 92 +++++++++++++++++++++++++++ 1 file changed, 92 insertions(+) create mode 100644 docs/ppl-lang/ppl-fillnull-command.md diff --git a/docs/ppl-lang/ppl-fillnull-command.md b/docs/ppl-lang/ppl-fillnull-command.md new file mode 100644 index 000000000..00064849c --- /dev/null +++ b/docs/ppl-lang/ppl-fillnull-command.md @@ -0,0 +1,92 @@ +## PPL `fillnull` command + +### Description +Using ``fillnull`` command to fill null with provided value in one or more fields in the search result. + + +### Syntax +`fillnull [with in ["," ]] | [using = ["," = ]]` + +* null-replacement: mandatory. The value used to replace `null`s. +* nullable-field: mandatory. Field reference. The `null` values in the field referred to by the property will be replaced with the values from the null-replacement. + + +### Example 1: fillnull one field + +The example show fillnull one field. + +PPL query: + + os> source=logs | fields status_code | eval input=status_code | fillnull value = 0 status_code; +| input | status_code | +|-------|-------------| +| 403 | 403 | +| 403 | 403 | +| NULL | 0 | +| NULL | 0 | +| 200 | 200 | +| 404 | 404 | +| 500 | 500 | +| NULL | 0 | +| 500 | 500 | +| 404 | 404 | +| 200 | 200 | +| 500 | 500 | +| NULL | 0 | +| NULL | 0 | +| 404 | 404 | + + +### Example 2: fillnull applied to multiple fields + +The example show fillnull applied to multiple fields. + +PPL query: + + os> source=logs | fields request_path, timestamp | eval input_request_path=request_path, input_timestamp = timestamp | fillnull value = '???' request_path, timestamp; +| input_request_path | input_timestamp | request_path | timestamp | +|--------------------|-----------------------|--------------|------------------------| +| /contact | NULL | /contact | ??? | +| /home | NULL | /home | ??? | +| /about | 2023-10-01 10:30:00 | /about | 2023-10-01 10:30:00 | +| /home | 2023-10-01 10:15:00 | /home | 2023-10-01 10:15:00 | +| NULL | 2023-10-01 10:20:00 | ??? | 2023-10-01 10:20:00 | +| NULL | 2023-10-01 11:05:00 | ??? | 2023-10-01 11:05:00 | +| /about | NULL | /about | ??? | +| /home | 2023-10-01 10:00:00 | /home | 2023-10-01 10:00:00 | +| /contact | NULL | /contact | ??? | +| NULL | 2023-10-01 10:05:00 | ??? | 2023-10-01 10:05:00 | +| NULL | 2023-10-01 10:50:00 | ??? | 2023-10-01 10:50:00 | +| /services | NULL | /services | ??? | +| /home | 2023-10-01 10:45:00 | /home | 2023-10-01 10:45:00 | +| /services | 2023-10-01 11:00:00 | /services | 2023-10-01 11:00:00 | +| NULL | 2023-10-01 10:35:00 | ??? | 2023-10-01 10:35:00 | + +### Example 3: fillnull applied to multiple fields with various `null` replacement values + +The example show fillnull with various values used to replace `null`s. +- `/error` in `request_path` field +- `1970-01-01 00:00:00` in `timestamp` field + +PPL query: + + os> source=logs | fields request_path, timestamp | eval input_request_path=request_path, input_timestamp = timestamp | fillnull using request_path = '/error', timestamp='1970-01-01 00:00:00'; + + +| input_request_path | input_timestamp | request_path | timestamp | +|--------------------|-----------------------|--------------|------------------------| +| /contact | NULL | /contact | 1970-01-01 00:00:00 | +| /home | NULL | /home | 1970-01-01 00:00:00 | +| /about | 2023-10-01 10:30:00 | /about | 2023-10-01 10:30:00 | +| /home | 2023-10-01 10:15:00 | /home | 2023-10-01 10:15:00 | +| NULL | 2023-10-01 10:20:00 | /error | 2023-10-01 10:20:00 | +| NULL | 2023-10-01 11:05:00 | /error | 2023-10-01 11:05:00 | +| /about | NULL | /about | 1970-01-01 00:00:00 | +| /home | 2023-10-01 10:00:00 | /home | 2023-10-01 10:00:00 | +| /contact | NULL | /contact | 1970-01-01 00:00:00 | +| NULL | 2023-10-01 10:05:00 | /error | 2023-10-01 10:05:00 | +| NULL | 2023-10-01 10:50:00 | /error | 2023-10-01 10:50:00 | +| /services | NULL | /services | 1970-01-01 00:00:00 | +| /home | 2023-10-01 10:45:00 | /home | 2023-10-01 10:45:00 | +| /services | 2023-10-01 11:00:00 | /services | 2023-10-01 11:00:00 | +| NULL | 2023-10-01 10:35:00 | /error | 2023-10-01 10:35:00 | \ No newline at end of file From 66f257e8c508417b7ec2845672ba60fe5cace8bd Mon Sep 17 00:00:00 2001 From: Lukasz Soszynski Date: Tue, 29 Oct 2024 17:40:46 +0100 Subject: [PATCH 2/2] Added reference ppl-fillnull-command.md in the PPL-Example-Commands.md file. Signed-off-by: Lukasz Soszynski --- docs/ppl-lang/PPL-Example-Commands.md | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/docs/ppl-lang/PPL-Example-Commands.md b/docs/ppl-lang/PPL-Example-Commands.md index d161613a6..9f14dcbae 100644 --- a/docs/ppl-lang/PPL-Example-Commands.md +++ b/docs/ppl-lang/PPL-Example-Commands.md @@ -397,7 +397,7 @@ _- **Limitation: another command usage of (relation) subquery is in `appendcols` ### Planned Commands: #### **fillnull** - +[See additional command details](ppl-fillnull-command.md) ```sql - `source=accounts | fillnull fields status_code=101` - `source=accounts | fillnull fields request_path='/not_found', timestamp='*'` @@ -405,4 +405,3 @@ _- **Limitation: another command usage of (relation) subquery is in `appendcols` - `source=accounts | fillnull using field1=concat(field2, field3), field4=2*pi()*field5` - `source=accounts | fillnull using field1=concat(field2, field3), field4=2*pi()*field5, field6 = 'N/A'` ``` -[See additional command details](planning/ppl-fillnull-command.md)