QueryCat 0.9.0
dotnet add package QueryCat --version 0.9.0
NuGet\Install-Package QueryCat -Version 0.9.0
<PackageReference Include="QueryCat" Version="0.9.0" />
paket add QueryCat --version 0.9.0
#r "nuget: QueryCat, 0.9.0"
// Install QueryCat as a Cake Addin #addin nuget:?package=QueryCat&version=0.9.0 // Install QueryCat as a Cake Tool #tool nuget:?package=QueryCat&version=0.9.0
QueryCat
QueryCat is the command line tool that allows you to use SQL (Structured Query Language) to query data in CSV, JSON, XML and various log files. The general idea is to bring well-known SQL expressive power and provide easy access to various kinds of information. You won't need to upload your text data into Excel or any database table - just query it as is with QueryCat!
- It is designed to use pipeline mode to be able to process large amount of data.
- INTO clause allows to write transformed data to popular formats.
- The single binary file doesn't require any dependencies to be installed and simplifies installation (just download and use).
- You can use it as library in your .NET application.
Features
- Query CSV, TSV, JSON, XML, log files and other input sources.
- Has simple SQL-engine that supports select, filter, group, joins, order, limit, offset, union, subqueries, CTE (recursive CTE), window functions.
- JSONPath, XPath expressions.
- Supports regex and Grok patterns.
- Simple Web UI and REST API.
- Simple files server (with partial request support).
- Plugins ecosystem.
- Variables support.
- Query .NET objects in your project (if used as library).
- AOT friendly.
In Action
Count total number of processes by user.
$ ps -ef | qcat "SELECT UID, COUNT(*) cnt FROM - GROUP BY UID ORDER BY cnt DESC LIMIT 3"
| UID | cnt |
| ---------- | ----- |
| root | 256 |
| ivan | 93 |
| systemd+ | 1 |
Calculate the total files size per user in a directory.
$ find /tmp -ls 2>/dev/null | qcat "SELECT column4 as user, size_pretty(SUM(column6)) size FROM - GROUP BY column4"
| user | size |
| ---------- | ---------- |
| root | 1.5K |
| ivan | 21.3M |
Select JSON logs exported from Google Cloud.
$ qcat 'SELECT "timestamp", insertId, json_value(jsonPayload, \'$.context.httpRequest.url\') as url, SUBSTR(json_value(jsonPayload, \'$.message\'), 0, 50) AS msg FROM \'downloaded-logs.json\' WHERE length(jsonPayload) > 0 ORDER BY "timestamp"'
| timestamp | insertId | url | msg |
| ------------------- | ----------------- | ---------- | -------------------------------------------------- |
| 03/30/2023 13:33:22 | gh53av89ifehmpo5e | NULL | "An TLS 1.1 connection request was received from a |
| 03/30/2023 13:33:22 | gh53av89ifehmpo5d | NULL | "An TLS 1.0 connection request was received from a |
| 03/30/2023 13:33:23 | gh53av89ifehmpo5o | NULL | "An TLS 1.1 connection request was received from a |
| 03/30/2023 13:33:24 | gh53av89ifehmpo5r | NULL | "An TLS 1.2 connection request was received from a |
| 03/30/2023 13:44:08 | gh53av89ifehmpo6b | NULL | "An error occurred while using SSL configuration f |
| 03/30/2023 13:51:38 | gh53av89ifehmpo6d | NULL | "An error occurred while using SSL configuration f |
| 03/30/2023 13:53:38 | rh4iofg12znj07 | "https://XXX/client/abort?transport=serverSentEvents\u0026clientProtocol=2.1\" | "System.Web.HttpException (0x80070057): The remote |
| 03/30/2023 13:53:51 | svb32tg14gii2c | "https://XXX/client/abort?transport=serverSentEvents\" | "System.Web.HttpException (0x80070057): The remote |
Show full user name for ps
command by joining with /etc/passwd
file.
$ ps aux | qcat "SELECT column4 USER, ps.PID, ps.COMMAND FROM - AS ps JOIN (SELECT * FROM '/etc/passwd' FORMAT csv(delimiter=>':', has_header=>false)) psw ON ps.USER = psw.column0"
| USER | ps.PID | ps.COMMAND |
| ---------- | ------ | ----------------------------- |
| | 1 | /sbin/init |
| | 2 | [kthreadd] |
| PolicyKit daemon | 976 | /usr/lib/polkit-1/polkitd |
Query CSV file with "a" and "b" numeric columns.
$ qcat --var csv=/tmp/1.csv "select a + b from csv"
3
7
NuGet Package
You can use the QueryCat library in your project. See SDK sections in the docs.
$ dotnet add package QueryCat
Information
- Home: GitHub
- Tutorial: ReadTheDocs
- Documentation: ReadTheDocs
- NuGet: NuGet
Limitations
- Not the whole SQL standard is implemented.
- Only limited amount of rows sources supports INSERT and UPDATE commands.
License
QueryCat is licensed under the MIT License - see the LICENSE file for details
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net8.0
- Antlr4.Runtime.Standard (>= 4.13.1)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.0)
-
net9.0
- Antlr4.Runtime.Standard (>= 4.13.1)
- Microsoft.Extensions.Logging.Abstractions (>= 9.0.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on QueryCat:
Package | Downloads |
---|---|
QueryCat.Plugins.Client
The assembly that helps you build plugins for QueryCat. Contains references to Thrift proxy and QueryCat core. |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
0.9.0 | 65 | 1/7/2025 |
0.8.1 | 1,095 | 11/11/2024 |
0.8.0 | 109 | 11/10/2024 |
0.8.0-alpha.33 | 86 | 10/18/2024 |
0.7.0 | 1,161 | 9/12/2024 |
0.6.9 | 881 | 8/6/2024 |
0.6.7 | 1,267 | 6/4/2024 |
0.6.4 | 273 | 5/20/2024 |
0.6.1 | 127 | 5/14/2024 |
0.6.0 | 141 | 4/30/2024 |
0.5.5 | 158 | 3/27/2024 |
0.5.4 | 136 | 3/1/2024 |
0.5.3 | 131 | 1/31/2024 |
0.5.0 | 192 | 12/31/2023 |
You can find changelog at https://github.com/krasninja/querycat/blob/develop/CHANGELOG.md