Table: json_key_value - Query Config JSON Key Values using SQL
The JSON Key Value is a resource within Config that allows you to monitor and manage your JSON key-value pairs across your applications and infrastructure. It provides a centralized way to set up and manage key-value pairs for various config resources, including virtual machines, databases, web applications, and more. Config JSON Key Value helps you stay informed about the health and performance of your config resources and take appropriate actions when predefined conditions are met.
Table Usage Guide
The json_key_value
table provides insights into JSON key-value pairs within Config. As a DevOps engineer, explore key-value specific details through this table, including keys, values, and associated metadata. Utilize it to uncover information about key-value pairs, such as those with specific keys, the relationships between keys and values, and the verification of key-value pairs.
For instance, if json_paths
is set to [ "/Users/myuser/*.json" ]
, and that directory contains:
- sample.json
- invoice.json
This table will retrieve all key-value pairs from each file mentioned above, along with line numbers, which you can then query directly:
select key_path, value, start_linefrom json_key_value;
+----------------------+-----------------------------+------------+| key_path | value | start_line |+----------------------+-----------------------------+------------+| items.1.part_no | E1628 | 19 || customer.first_name | Dorothy | 6 || city | East Centerville | 3 || items.1.size | 8 | 22 || items.1.price | 133.7 | 20 || items.1.quantity | 1 | 21 || street | 123 Tornado Alley | 28 || | Suite 16 | || state | KS | 27 || items.0.description | Water Bucket (Filled) | 12 || items.0.price | 1.47 | 14 || date | 2012-08-06T00:00:00Z | 9 || items.0.part_no | A4786 | 13 || items.1.description | High Heeled "Ruby" Slippers | 18 || customer.family_name | Gale | 5 || receipt | Oz-Ware Purchase Invoice | 25 || items.0.quantity | 4 | 15 |+----------------------+-----------------------------+------------+
or, you can query configurations of a particular file using:
select key_path, value, pathfrom json_key_valuewhere path = '/Users/myuser/json/invoice.json';
+----------------------+-----------------------------+---------------------------------+| key_path | value | path |+----------------------+-----------------------------+---------------------------------+| items.1.size | 8 | /Users/myuser/json/invoice.json || customer.family_name | Gale | /Users/myuser/json/invoice.json || items.1.part_no | E1628 | /Users/myuser/json/invoice.json || items.0.part_no | A4786 | /Users/myuser/json/invoice.json || items.0.price | 1.47 | /Users/myuser/json/invoice.json || date | 2012-08-06 | /Users/myuser/json/invoice.json || items.1.price | 133.7 | /Users/myuser/json/invoice.json || customer.first_name | Dorothy | /Users/myuser/json/invoice.json || includes.0 | common.yaml | /Users/myuser/json/invoice.json || foo | bar | /Users/myuser/json/invoice.json || items.1.description | High Heeled "Ruby" Slippers | /Users/myuser/json/invoice.json || receipt | Oz-Ware Purchase Invoice | /Users/myuser/json/invoice.json || items.0.quantity | 4 | /Users/myuser/json/invoice.json || items.0.description | Water Bucket (Filled) | /Users/myuser/json/invoice.json || city | East Centerville | /Users/myuser/json/invoice.json || items.1.quantity | 1 | /Users/myuser/json/invoice.json |+----------------------+-----------------------------+---------------------------------+
Examples
The key_path
column's data type is
ltree, so all key_path
values are stored as dot-delimited label paths. This enables the use of the
usual comparison operators along with ltree
operators and functions which can
be used to match subpaths, find ancestors and descendants, and search arrays.
For all examples below, assume we're using the file invoice.json
with the following configuration:
{ "bill-to": null, "city": "East Centerville", "customer": { "family_name": "Gale", "first_name": "Dorothy" }, "date": "2012-08-06T00:00:00Z", "items": [ { "description": "Water Bucket (Filled)", "part_no": "A4786", "price": 1.47, "quantity": 4 }, { "description": "High Heeled \"Ruby\" Slippers", "part_no": "E1628", "price": 133.7, "quantity": 1, "size": 8 } ], "receipt": "Oz-Ware Purchase Invoice", "ship-to": null, "state": "KS", "street": "123 Tornado Alley\nSuite 16\n"}
Query a specific key-value pair
Analyze the contents of a specific JSON file to identify a particular item's part number. This is beneficial in situations where you need to quickly access a specific detail from a large dataset, such as an invoice, without having to manually search through the entire document. You can query a specific key path to get its value:
select key_path, value as part_nofrom json_key_valuewhere path = '/Users/myuser/json/invoice.json' and key_path = 'items.0.part_no';
select key_path, value as part_nofrom json_key_valuewhere path = '/Users/myuser/json/invoice.json' and key_path = 'items.0.part_no';
+-----------------+-------+| key_path | value |+-----------------+-------+| items.0.part_no | A4786 |+-----------------+-------+
Query using comparison operators
Explore specific segments of a JSON file, such as 'invoice.json', to identify key data points. This can be useful in scenarios where you want to examine certain parts of your data without going through the entire file.
The usual comparison operators, like <
, >
, <=
, and >=
work with ltree
columns.
For instance, you can use the <
operator to query all key paths that are before items
alphabetically:
select key_path, value as part_nofrom json_key_valuewhere path = '/Users/myuser/json/invoice.json' and key_path < 'items';
select key_path, value as part_nofrom json_key_valuewhere path = '/Users/myuser/json/invoice.json' and key_path < 'items';
+----------------------+----------------------+| key_path | part_no |+----------------------+----------------------+| bill_to | <null> || city | East Centerville || customer.family_name | Gale || customer.first_name | Dorothy || date | 2012-08-06T00:00:00Z |+----------------------+----------------------+
Query using path matching
Explore which parts are listed in a specific invoice file, allowing you to assess the items included in transactions without manually navigating the JSON file.
ltree
also supports additional operators like ~
which can be used to find all part_no
subkeys:
select key_path, value as part_nofrom json_key_valuewhere path = '/Users/myuser/json/invoice.json' and key_path ~ 'items.*.part_no';
Error: SQLite does not support regular expressions.
+-----------------+---------+| key_path | part_no |+-----------------+---------+| items.1.part_no | E1628 || items.0.part_no | A4786 |+-----------------+---------+
List descendants of a specific node
Explore the specific sections of a JSON file to uncover the details related to a particular keyword. This can be useful in scenarios where you need to understand the information related to a particular user or entity within a larger dataset.
select key_path, valuefrom json_key_valuewhere path = '/Users/myuser/json/invoice.json' and key_path < @ 'customer';
Error: SQLite does not support array operators like < @.
+----------------------+---------+| key_path | value |+----------------------+---------+| customer.first_name | Dorothy || customer.family_name | Gale |+----------------------+---------+
Create a pivot table and search for a specific key
This example demonstrates how to organize and search for specific information within a JSON invoice document. It's useful for gaining insights into individual items, such as their part numbers, descriptions, sizes, quantities, and prices.
with items as ( select subpath(key_path, 0, 2) as item, subpath(key_path, 2, 3) as data, value from json_key_value where path = '/Users/myuser/json/invoice.json' and key_path ~ 'items.*')select max( case when data = 'part_no' then value else null end ) as part_no, max( case when data = 'description' then value else null end ) as item_name, max( case when data = 'size' then value else null end ) as size, max( case when data = 'quantity' then value else null end ) as quantity, max( case when data = 'price' then value else null end ) as pricefrom itemsgroup by item;
Error: SQLite does not support the subpathand ~ (regex match) functions used in the PostgreSQL query.
+---------+-----------------------------+--------+----------+-------+| part_no | item_name | size | quantity | price |+---------+-----------------------------+--------+----------+-------+| A4786 | Water Bucket (Filled) | <null> | 4 | 1.47 || E1628 | High Heeled "Ruby" Slippers | 8 | 1 | 133.7 |+---------+-----------------------------+--------+----------+-------+
You can also check the value for a particular key:
with items as ( select subpath(key_path, 0, 2) as item, subpath(key_path, 2, 3) as data, value from json_key_value where path = '/Users/myuser/json/invoice.json' and key_path ~ 'items.*'),pivot_tables as ( select max( case when data = 'part_no' then value else null end ) as part_no, max( case when data = 'description' then value else null end ) as item_name, max( case when data = 'size' then value else null end ) as size, max( case when data = 'quantity' then value else null end ) as quantity, max( case when data = 'price' then value else null end ) as price from items group by item)select *from pivot_tableswhere part_no = 'E1628';
Error: SQLite does not support subpathand ~ (regular expression) functions.
+---------+-----------------------------+--------+----------+-------+| part_no | item_name | size | quantity | price |+---------+-----------------------------+--------+----------+-------+| E1628 | High Heeled "Ruby" Slippers | 8 | 1 | 133.7 |+---------+-----------------------------+--------+----------+-------+
Casting column data for analysis
Determine the areas in which specific item details, such as part number, name, size, quantity, and price, can be extracted and analyzed from a JSON invoice file. This is useful for gaining insights into individual product data for further business analysis and decision-making.
The value
column data type is text
, so you can easily cast it when required:
with items as ( select subpath(key_path, 0, 2) as item, subpath(key_path, 2, 3) as data, value from json_key_value where path = '/Users/myuser/json/invoice.json' and key_path ~ 'items.*')select max( case when data = 'part_no' then value else null end ) as part_no, max( case when data = 'description' then value else null end ) as item_name, ( max( case when data = 'size' then value else null end ) ) :: integer as size, ( max( case when data = 'quantity' then value else null end ) ) :: integer as quantity, ( max( case when data = 'price' then value else null end ) ) :: float as pricefrom itemsgroup by item;
Error: SQLite does not support regular expressionsand array functions like 'subpath'and '~' used in the PostgreSQL query.
+---------+-----------------------------+--------+----------+-------+| part_no | item_name | size | quantity | price |+---------+-----------------------------+--------+----------+-------+| A4786 | Water Bucket (Filled) | <null> | 4 | 1.47 || E1628 | High Heeled "Ruby" Slippers | 8 | 1 | 133.7 |+---------+-----------------------------+--------+----------+-------+
Schema for json_key_value
Name | Type | Operators | Description |
---|---|---|---|
_ctx | jsonb | Steampipe context in JSON form, e.g. connection_name. | |
key_path | ltree | Specifies full path of a key in JSON file. | |
keys | jsonb | The array representation of path of a key. | |
path | text | = | Specifies the path of the JSON file. |
start_column | bigint | Specifies the starting column of the value. | |
start_line | bigint | Specifies the line number where the value is located. | |
value | text | Specifies the value of the corresponding key. |
Export
This table is available as a standalone Exporter CLI. Steampipe exporters are stand-alone binaries that allow you to extract data using Steampipe plugins without a database.
You can download the tarball for your platform from the Releases page, but it is simplest to install them with the steampipe_export_installer.sh
script:
/bin/sh -c "$(curl -fsSL https://steampipe.io/install/export.sh)" -- config
You can pass the configuration to the command with the --config
argument:
steampipe_export_config --config '<your_config>' json_key_value