Simple SQL REPL Command Handler
Project description
squelch
Squelch is a package providing a Simple SQL REPL Command Handler. Squelch uses SQLAlchemy for database access and so can support any database engine that SQLAlchemy supports, thereby providing a common database client experience for any of those database engines. Squelch is modelled on a simplified psql, the PostgreSQL command line client. The Squelch CLI supports readline history and basic SQL statement tab completions.
Install
The package can be installed from PyPI:
$ pip install squelch
From the command line
The package comes with a functional CLI called squelch, which just calls the package main, hence the following two invocations are equivalent:
$ python3 -m squelch
$ squelch
The only required argument is a database connection URL. This can either be passed on the command line, via the --url option, or specified in a JSON configuration file.
The configuration file can be specified in one of the following ways:
- The full path to a configuration file can be given by the
--conf-fileoption. - A configuration name can be given as the first positional argument.
A configuration name is the basename (without the .json suffix) of a configuration file in the squelch configuration directory. Using a configuration name is a convenience that simplifies the invocation of the CLI.
The form of the JSON configuration file is as follows:
{
"url": "<URL>"
}
where the <URL> follows the SQLAlchemy database connection URL syntax. An advantage of using a configuration file is that it avoids providing database login credentials in plain text on the command line.
Configuration directory
The configuration directory is $XDG_CONFIG_HOME/squelch. If the environment variable $XDG_CONFIG_HOME is not set in the caller environment, then it falls back to ~/.config/squelch, as per the XDG specifications.
Specifying a configuration name
Given the following configuration directory contents:
$ ls ~/.config/squelch/
extras.json min.json queries.sql test.json
the user can pass the configuration name extras as the first positional argument, and the CLI will find the full path to the corresponding configuration file (~/.config/squelch/extras.json) and use it to connect to the database specified by the URL in the JSON object:
$ squelch extras
Running queries
When running the CLI in a terminal, the user is dropped into an interactive REPL. From here, the user is prompted for input, which can be an SQL statement to be sent to the database engine, or a CLI command (backslash command) such as \q to quit the CLI:
$ python -m squelch -c tests/data/test.json
squelch (0.3.0)
Type "help" for help.
tests/data/test.db => select * from data;
id | name | status | key
------+--------+----------+-----------
1 | pmb | 0 | 0000-0000
2 | abc | 0 | 0000-0001
3 | def | 0 | 0000-0002
4 | ghi | 1 | 0000-0003
(4 rows)
tests/data/test.db => \q
Alternatively, the CLI can be called as a one-shot by providing a query on stdin, thereby allowing it to be called in scripts.
For example, using echo to pipe a query to the CLI:
$ echo "select * from data" | python -m squelch -c tests/data/test.json
id | name | status | key
------+--------+----------+-----------
1 | pmb | 0 | 0000-0000
2 | abc | 0 | 0000-0001
3 | def | 0 | 0000-0002
4 | ghi | 1 | 0000-0003
(4 rows)
Or redirecting from a file. Given the following queries in a file:
$ cat tests/data/queries.sql
select * from data;
select * from data where id = 1;
select * from status where status = 1;
the result would be:
$ python -m squelch -c tests/data/test.json < tests/data/queries.sql
id | name | status | key
------+--------+----------+-----------
1 | pmb | 0 | 0000-0000
2 | abc | 0 | 0000-0001
3 | def | 0 | 0000-0002
4 | ghi | 1 | 0000-0003
(4 rows)
id | name | status | key
------+--------+----------+-----------
1 | pmb | 0 | 0000-0000
(1 row)
name | status
--------+----------
ghi | 1
(1 row)
Machine-readable data in scripts
It's likely that when calling the CLI from a script, the user is less interested in the data being laid out in a human-readable table, rather, they probably want it as machine-readable data. The table format can be set (using the --pset option) to csv so that the table is printed as CSV. Additionally, the table footer can be turned off (again using --pset) so that the result is just a simple CSV table. Taking our example from earlier, the result would be:
$ echo "select * from data;" | python -m squelch -c tests/data/test.json --pset format=csv --pset footer=off
id,name,status,key
1,pmb,0,0000-0000
2,abc,0,0000-0001
3,def,0,0000-0002
4,ghi,1,0000-0003
Command line usage
usage: squelch [-h] [-c CONF_FILE] [-u URL] [-S [NAME=VALUE [NAME=VALUE ...]]]
[-P [NAME=VALUE [NAME=VALUE ...]]] [-v] [-V]
[conf_name]
Squelch is a Simple SQL REPL Command Handler.
positional arguments:
conf_name The name of a JSON configuration in the default
configuration directory (/home/pbree/.config/squelch).
optional arguments:
-h, --help show this help message and exit
-c CONF_FILE, --conf-file CONF_FILE
The full path to a JSON configuration file.
-u URL, --url URL The database connection URL, as required by
sqlalchemy.create_engine().
-S [NAME=VALUE [NAME=VALUE ...]], --set [NAME=VALUE [NAME=VALUE ...]]
Set state variable NAME to VALUE.
-P [NAME=VALUE [NAME=VALUE ...]], --pset [NAME=VALUE [NAME=VALUE ...]]
Set printing state variable NAME to VALUE.
-v, --verbose Turn verbose messaging on. The effects of this option
are incremental.
-V, --version show program's version number and exit
Database Connection URL
The database connection URL can either be passed on the command line, via the --url option, or specified in a JSON configuration file given by the --conf-file option. The form of the JSON configuration file is as follows:
{
"url": "<URL>"
}
From the SQLAlchemy documentation:
"The string form of the URL is dialect[+driver]://user:password@host/dbname[?key=value..], where dialect is a database name such as mysql, oracle, postgresql, etc., and driver the name of a DBAPI, such as psycopg2, pyodbc, cx_oracle, etc. Alternatively, the URL can be an instance of URL."
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file squelch-0.4.0.tar.gz.
File metadata
- Download URL: squelch-0.4.0.tar.gz
- Upload date:
- Size: 20.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.2.2 CPython/3.8.10 Linux/5.15.0-124-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7363b465fed2740e14a91909a10425a2f501d138684dbd267916b139781185f0
|
|
| MD5 |
0e54d69ab4e82481cd0756edfbb7e16b
|
|
| BLAKE2b-256 |
79df6e53d3461e41e2cc473d32f4d0cd59e17a435fb4859c5fc3e8cc127f3f29
|
File details
Details for the file squelch-0.4.0-py3-none-any.whl.
File metadata
- Download URL: squelch-0.4.0-py3-none-any.whl
- Upload date:
- Size: 18.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.2.2 CPython/3.8.10 Linux/5.15.0-124-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0f3782e6554a364c6dfdd67e532edd526a1f067a236e0e21cc29f31a17f86198
|
|
| MD5 |
e31befba2daa6a0b0c33ecddf23ad7e4
|
|
| BLAKE2b-256 |
cc5449674707c4c8adb5b3baa9caff0784aa4216c6ae54e42fc081c98c64c348
|