Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/theseus-rs/rsql
Command line interface for DuckDB, LibSQL, MariaDB, MySQL, PostgreSQL, Redshift, Snowflake, SQLite3 and SQL Server
https://github.com/theseus-rs/rsql
command-line data database duckdb mariadb mysql postgres postgresql redshift rust snowflake sql sqlite sqlite3 sqlserver
Last synced: 2 days ago
JSON representation
Command line interface for DuckDB, LibSQL, MariaDB, MySQL, PostgreSQL, Redshift, Snowflake, SQLite3 and SQL Server
- Host: GitHub
- URL: https://github.com/theseus-rs/rsql
- Owner: theseus-rs
- License: apache-2.0
- Created: 2024-03-11T00:16:55.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-10-29T18:32:27.000Z (3 months ago)
- Last Synced: 2024-10-29T20:37:46.406Z (3 months ago)
- Topics: command-line, data, database, duckdb, mariadb, mysql, postgres, postgresql, redshift, rust, snowflake, sql, sqlite, sqlite3, sqlserver
- Language: Rust
- Homepage: https://theseus-rs.github.io/rsql/rsql_cli/
- Size: 38.4 MB
- Stars: 123
- Watchers: 1
- Forks: 5
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE-APACHE
- Security: SECURITY.md
Awesome Lists containing this project
README
# rsql
[![ci](https://github.com/theseus-rs/rsql/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/theseus-rs/rsql/actions/workflows/ci.yml)
[![Documentation](https://docs.rs/rsql_core/badge.svg)](https://docs.rs/rsql_core)
[![Code Coverage](https://codecov.io/gh/theseus-rs/rsql/branch/main/graph/badge.svg)](https://codecov.io/gh/theseus-rs/rsql)
[![Benchmarks](https://img.shields.io/badge/%F0%9F%90%B0_bencher-enabled-6ec241)](https://bencher.dev/perf/theseus-rs-rsql)
[![Latest version](https://img.shields.io/crates/v/rsql_cli.svg)](https://crates.io/crates/rsql_cli)
[![Github All Releases](https://img.shields.io/github/downloads/theseus-rs/rsql/total.svg)](https://theseus-rs.github.io/rsql/rsql_cli/)
[![License](https://img.shields.io/crates/l/rsql_cli)](https://github.com/theseus-rs/rsql_cli#license)
[![Semantic Versioning](https://img.shields.io/badge/%E2%9A%99%EF%B8%8F_SemVer-2.0.0-blue)](https://semver.org/spec/v2.0.0.html)`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
```shell
curl --proto '=https' --tlsv1.2 -LsSf https://github.com/theseus-rs/rsql/releases/latest/download/rsql_cli-installer.sh | sh
```### Windows
```shell
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](https://theseus-rs.github.io/rsql/rsql_cli/) site.![](./rsql_cli/resources/demo.gif)
## 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
```shell
rsql --url ""
```### Running a single Query
```shell
rsql --url "" -- ""
```| Driver | URL |
|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| arrow (polars) | `arrow://` |
| avro (polars) | `avro://` |
| cockroachdb (sqlx) | `cockroachdb://]@[:]/` |
| csv (polars) | `csv://[?has_header=]["e=][&skip_rows=]` |
| delimited (polars) | `delimited://[?separator=][&has_header=]["e=][&skip_rows=]` |
| duckdb | `duckdb://[]` |
| excel | `excel://[?has_header=][&skip_rows=]` |
| file¹ | `file://` |
| json (polars) | `json://` |
| jsonl (polars) | `jsonl://` |
| libsql² | `libsql://?[][&file=][&auth_token=]` |
| mariadb (sqlx) | `mariadb://[:]@[:]/` |
| mysql (sqlx) | `mysql://[:]@[:]/` |
| ods | `ods://[?has_header=][&skip_rows=]` |
| parquet (polars) | `parquet://` |
| postgres | `postgres://[:]@[:]/?` |
| postgresql (sqlx) | `postgresql://[:]@[:]/?` |
| redshift (sqlx) | `redshift://]@[:]/` |
| rusqlite | `rusqlite://[]` |
| snowflake | `snowflake://[:]@.snowflakecomputing.com/[?private_key_file=pkey_file&public_key_file=pubkey_file]` |
| sqlite (sqlx) | `sqlite://[]` |
| sqlserver | `sqlserver://[:]@[:]/` |
| tsv (polars) | `tsv://[?has_header=]["e=][&skip_rows=]` |
| xml | `xml://` |
| yaml | `yaml://` |¹ 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:
- Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or )
- MIT license ([LICENSE-MIT](LICENSE-MIT) or )## 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.