From 0ec6aeff9e9e401114ffbc9ce51d528f8a0bfc23 Mon Sep 17 00:00:00 2001 From: Lorenzo Mangani Date: Thu, 2 Jan 2025 20:06:17 +0100 Subject: [PATCH] Update README.md --- README.md | 38 ++++++++++++++++++++++++++++++++++++-- 1 file changed, 36 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 57c5692..8c4a133 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@ - + -> _a pipe for quackheads_ +> _a data pipe for quackheads_ # :baby_chick: quackpipe @@ -95,6 +95,40 @@ Execute queries using STDIN hello,v1.1.1 ``` +### :fist_right: Clickhouse SQL (chsql) +Quackpipe speaks a little ClickHouse SQL using the [chsql](https://community-extensions.duckdb.org/extensions/chsql.html) DuckDB Extension providing users with [100+ ClickHouse SQL Command Macros](https://community-extensions.duckdb.org/extensions/chsql.html#added-functions) two clients _(HTTP/S and Native)_ to interact with remote ClickHouse APIs + +#### Example +```sql +--- Install and load chsql +D INSTALL chsql FROM community; +D LOAD chsql; + +--- Use any of the 100+ ClickHouse Function Macros +D SELECT IPv4StringToNum('127.0.0.1'), IPv4NumToString(2130706433); +┌──────────────────────────────┬─────────────────────────────┐ +│ ipv4stringtonum('127.0.0.1') │ ipv4numtostring(2130706433) │ +│ int32 │ varchar │ +├──────────────────────────────┼─────────────────────────────┤ +│ 2130706433 │ 127.0.0.1 │ +└──────────────────────────────┴─────────────────────────────┘ +``` + +### Remote Queries +The built-in `ch_scan` function can be used to query remote ClickHouse servers using the HTTP/s API +```sql +--- Set optional X-Header Authentication +D CREATE SECRET extra_http_headers ( + TYPE HTTP, + EXTRA_HTTP_HEADERS MAP{ + 'X-ClickHouse-User': 'user', + 'X-ClickHouse-Key': 'password' + } + ); +--- Query using the HTTP API +D SELECT * FROM ch_scan("SELECT number * 2 FROM numbers(10)", "https://play.clickhouse.com"); +``` + ### :fist_right: Extensions Several extensions are pre-installed by default in [Docker images](https://github.com/metrico/quackpipe/blob/main/Dockerfile#L9), including _parquet, json, httpfs_
When using HTTP API, _httpfs, parquet, json_ extensions are automatically pre-loaded by the wrapper.