Skip to content

Command line SQL interface for relational databases and common data file formats

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT
Notifications You must be signed in to change notification settings

theseus-rs/rsql

rsql

ci Documentation Code Coverage Benchmarks Latest version Github All Releases License Semantic Versioning

rsql is a command line interface for databases. rsql is a modern, feature-rich, and user-friendly database client, that has been designed to be easy to use, and to provide a consistent experience across all supported databases. The project aims to provide reusable components for building other database clients.

Getting Started

rsql can be installed using the following methods:

Linux / MacOS

curl --proto '=https' --tlsv1.2 -LsSf https://github.com/theseus-rs/rsql/releases/latest/download/rsql_cli-installer.sh | sh

Windows

irm https://github.com/theseus-rs/rsql/releases/latest/download/rsql_cli-installer.ps1 | iex

For more information, and additional installations instructions (cargo, homebrew, msi), visit the rsql site.

Features

Feature
Databases Arrow, Avro, CockroachDB, CSV, Delimited, DuckDB, Excel, JSON, JSONL, LibSQL (Turso), MariaDB, MySQL, ODS, Parquet, PostgreSQL, Redshift, Snowflake, SQLite3, SQL Server, TSV, XML, YAML
Syntax Highlighting
Result Highlighting
Query Auto-completion
History
SQL File Execution
Embedded PostgreSQL
Output Formats ascii, csv, expanded, html, json, jsonl, markdown, plain, psql, sqlite, tsv, unicode, xml, yaml
Localized Interface 40+ languages¹
Key Bindings emacs, vi

¹ Computer translations; human translations welcome

Usage

Interactive Mode

rsql --url "<url>"

Running a single Query

rsql --url "<url>" -- "<query>"
Driver URL
arrow (polars) arrow://<file>
avro (polars) avro://<file>
cockroachdb (sqlx) cockroachdb://<user[:password>]@<host>[:<port>]/<database>
csv (polars) csv://<file>[?has_header=<true/false>][&quote=<char>][&skip_rows=<n>]
delimited (polars) delimited://<file>[?separator=<char>][&has_header=<true/false>][&quote=<char>][&skip_rows=<n>]
duckdb duckdb://[<file>]
excel excel://<file>[?has_header=<true/false>][&skip_rows=<n>]
file¹ file://<file>
json (polars) json://<file>
jsonl (polars) jsonl://<file>
libsql² libsql://<host>?[<memory=true>][&file=<database_file>][&auth_token=<token>]
mariadb (sqlx) mariadb://<user>[:<password>]@<host>[:<port>]/<database>
mysql (sqlx) mysql://<user>[:<password>]@<host>[:<port>]/<database>
ods ods://<file>[?has_header=<true/false>][&skip_rows=<n>]
parquet (polars) parquet://<file>
postgres postgres://<user>[:<password>]@<host>[:<port>]/<database>?<embedded=true>
postgresql (sqlx) postgresql://<user>[:<password>]@<host>[:<port>]/<database>?<embedded=true>
redshift (sqlx) redshift://<user[:password>]@<host>[:<port>]/<database>
rusqlite rusqlite://[<file>]
snowflake snowflake://<user>[:<token>]@<account>.snowflakecomputing.com/[?private_key_file=pkey_file&public_key_file=pubkey_file]
sqlite (sqlx) sqlite://[<file>]
sqlserver sqlserver://<user>[:<password>]@<host>[:<port>]/<database>
tsv (polars) tsv://<file>[?has_header=<true/false>][&quote=<char>][&skip_rows=<n>]
xml xml://<file>
yaml yaml://<file>

¹ the file driver will attempt to detect the type of file and automatically use the appropriate driver.
² libsql needs to be enabled with the libsql feature flag; it is disabled by default as it conflicts with rusqlite.

Safety

These crates use #![forbid(unsafe_code)] to ensure everything is implemented in 100% safe Rust.

License

Licensed under either of:

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

VSCode Development Container
GitHub Codespaces