Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/muhmud/qsh
shell-based query tool
https://github.com/muhmud/qsh
Last synced: about 1 month ago
JSON representation
shell-based query tool
- Host: GitHub
- URL: https://github.com/muhmud/qsh
- Owner: muhmud
- Created: 2020-11-09T17:43:22.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-02-10T19:33:16.000Z (10 months ago)
- Last Synced: 2024-08-01T16:43:39.837Z (4 months ago)
- Language: Shell
- Homepage:
- Size: 2.57 MB
- Stars: 164
- Watchers: 6
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- my-awesome-github-stars - muhmud/qsh - shell-based query tool (Shell)
README
# qsh
Query SHell - improved querying from your terminal![QSH](images/qsh-querying.gif)
Currently supports:
* `sqlite3` (3.37+)
* `mysql`
* `psql`
* `sqlcmd` (for `mssql`)
* `sqlcl` (for `oracle`)
* `mclient` (for `monetdb`)There is also a generic mode, which can potentially be used with other tools not on this list. The generic mode can be used with non-database tools as well, like the `redis-cli`, REPLs and even shells, such as `bash`. See the [usage](https://github.com/muhmud/qsh/#generic-mode) section below for more details.
## Prerequisites
You'll need to install & use [tmux](https://github.com/tmux/tmux), which is needed to manage the split panes. It should be available from your package manager. Installing [jq](https://github.com/stedolan/jq) and `tree` would also be a good idea. For the generic mode, you will need `rlwrap` and `perl`.
For better viewing of SQL results, the [pspg](https://github.com/okbob/pspg) pager is recommended (ensure you have the latest version), however, you could also use `less -SinFX`. When displaying results, qsh will try to make a sensible choice, however, you can instead explicitly choose a pager. For generic mode, `bat` can also work well.
To format SQL statements, you will need python 3 and [sqlparse](https://github.com/andialbrecht/sqlparse).
**Note: If you have issues, make sure your local install of `qsh` is fully [up-to-date](https://github.com/muhmud/qsh/#updating).**
## Setup
Clone this repository to your home:
```bash
$ git clone https://github.com/muhmud/qsh.git ~/.qsh
```And then add the `~/.qsh/bin` directory to your `PATH`.
You now just need to setup the editor you want to use for writing SQL statements, which will be triggered from your SQL client tool. If you want to, and it's recommended, you can setup a keyboard shortcut for this in your tmux config. This will give you the same consistent shortcut for starting the editor from any tool.
The following example does this for `Alt-q`:
```
# qsh
bind-key -n M-q run-shell ~/.qsh/bin/qsh-start
```You can currently use either `vim`/`nvim` or `micro`. Whichever you choose, make sure your `QSH_EDITOR` or `EDITOR`/`VISUAL` environment variable is set appropriately.
### vim/nvim
#### vim-plug
```
Plug 'muhmud/qsh', { 'dir': '~/.qsh', 'branch': 'main', 'rtp': 'editors/vim' }
```#### packer
```
{ "~/.qsh/editors/vim", as = "Qsh" }
```The default key mappings can be found [here](https://github.com/muhmud/qsh/blob/main/editors/vim/plugin/qsh.vim#L24-L95). You can disable them by setting `g:qsh_enable_key_mappings` to `0`.
You can add custom key mappings like this:
```
autocmd Filetype sql call QshCustomSqlKeyMappings()
function QshCustomSqlKeyMappings()
...
endfunction
```### Micro
The [micro](https://micro-editor.github.io/) plugin can be installed by executing the following:
```bash
$ mkdir -p ~/.config/micro/plug && cp -r ~/.qsh/editors/micro ~/.config/micro/plug/qsh
```The following key mappings, or similar, can be added to `~/.config/micro/bindings.json`:
```
"Alt-g": "command:QshExecute",
"Alt-G": "command:QshExecute '^---$' 0",
"Alt-e": "command:QshExecuteSelection",
"Alt-y": "command:QshExecuteAll",
"Alt-d": "command:QshExecuteNamedScript 'describe'",
"Alt-r": "command:QshExecuteNamedScript 'select-some'",
"Alt-v": "command:QshExecuteScript",
"Alt-i": "command:QshExecuteSnippet",
"Alt-t": "command:QshExecuteNamedSnippet 'format'",
"Alt-p": "command:QshSetUnsetPrefix"
```## Usage
From within a `tmux` session, prefix the invocation of your SQL client with `qsh`:
```
$ qsh psql
```This will setup your SQL client environment appropriately. Now, trigger the editor using the command for your environment. For `mysql`, this would be `\e;`, and for `psql`, `\e` or if you setup a keyboard shortcut in your tmux config, as described above, you could use that also. Alternatively, use the `-s` option to startup the editor automatically.
You should see the editor pane created, where you can now type in queries. A default SQL file is created for you, however, you could open up any other file you need to.
**Note: For `sqlcl`, you would start the editor by using `@qsh`**
### Generic Mode
If you invoke a tool that `qsh` does not know about, it will go into generic mode and will attempt to give you a usable querying experience, so you shouldn't need to do anything differently.
![Generic](images/qsh-generic.gif)
If your terminal looks messed up when the tool starts, try to use the REPL mode by specifying the `-r` option:
```
$ qsh -r redis-cli
```You can also use the `-f` option to change the extension of the file opened up in the editor. This can be useful to enable language/domain specific features for the tool you are using. Setting this value to something that isn't `sql` implicitly enables REPL mode:
```
$ qsh -f js node
```You can use scripts and snippets with generic mode tools by setting the `QSH_SCRIPTS_PATH` and `QSH_SNIPPETS_PATH` environment variables. See the sections below for details on how these work.
You can register the settings you use for generic tools, including certain environment variables, just as you would register a connection for a database. This makes it easier to invoke the tool in the same way in the future. See the [registering connections](https://github.com/muhmud/qsh/#registering-connections) section for more details, or just run the `qsh` and/or `qsh-reg` tools without any arguments.
For example, the following registers an invocation for using `qsh` with `zsh`:
```
$ QSH_EDITOR_COMMAND="\u001B\u0016" \
QSH_NEWLINE_ON_COMMAND=1 \
VISUAL=~/.qsh/scripts/qsh \
qsh-reg -gisf sh zsh zsh
```* `-g` - Grab environment variables, which will be restored when the tool is started
* `-i` - Invoke the tool as is, i.e. without `rlwrap`
* `-s` - Go straight into editor mode
* `-f sh` - Set the file extension for the default file opened up in the editor to `sh`
* `zsh` - The name of the invocation to create
* `zsh` - The actual invocation of zshNow this invocation of qsh can be started like this:
```
$ qsh zsh
```#### Prefix
You can set `qsh` to add a prefix to every command you want to execute, which can be sometimes be useful in generic mode, for example, when running `git` or `kubectl` commands. This way you don't need to repeat this command every time.
### Executing Queries
* `Alt-e` - Highlight a query to run and execute it
* `Alt-g` - Execute a query without needing to highlight it
* `Alt-G` - Execute multiple statements or function/procedure definitions without needing to highlight
* `Alt-y` - Execute everything in the editor bufferFor `Alt-g`, `qsh` will look for a statement delimited on either side by a semi-colon. This makes it easier to execute a large SQL statement without needing to highlight it every time.
Alternatively, using `Alt-G` does the same thing but changes the delimiter to be the string `---`, which must be the only thing on a line. You can change this to whatever you like, this is simply the default as defined in the key mapping.
The following provides an example:
```sql
create procedure test(a int)
begin
update test
set a = 1; /* <- If the cursor is here, Alt-G will create procedure test only */
end;--- /* <- This is the customizable delimiter defined in the key binding */
create procedure test2(a int)
begin
update test
set a = 2; /* <- If the cursor is here, Alt-G will create procedure test2 only */
end;
```### Scripts
* `Alt-v` - Execute a script, which can be done with or without highlighting
Scripts are shortcuts for SQL statements that return a consistent data set across different database servers. For example, to get a list of tables in the current database, whether `mysql` or `postgresql`, execute the following script(s):
![Scripts](images/qsh-scripts.gif)
You can also apply additional filtering & sorting to scripts (you must highlight the query for this to work):
```
tables
where table_schema = 'public'
order by table_rows desc
```There are quite a few scripts available. You can see what they are by executing the `scripts` script. You can also add you own custom scripts to `~/.qsh/clients/psql/scripts` or `~/.qsh/clients/mysql/scripts`, depending on the database platform you are targeting.
For reference, here is an example of the kinds of scripts available:
```
$ ls ~/.qsh/clients/psql/scripts
all-columns all-references all-sessions columns procedures scripts tables
all-databases all-routines all-tables databases references select triggers
all-functions all-schemas all-triggers describe routines select-some views
all-procedures all-select all-views functions schemas sessions```
You can keep your own scripts in separate directories and have `qsh` include them in its search by adding them to the `QSH_SCRIPTS_PATH` environment variable.
#### Named Scripts
* `Alt-d` - Describe a particular table, which may or may not be highlighted
* `Alt-r` - Select some of the data for a particular tableNamed scripts take information from the editor as a payload, which is used to provide context. The scripts mentioned above are created by default, however, you can also add your own.
You can either highlight the name of the table to be used with these scripts, however, it's also OK for the cursor to simply be on the table name.
### Snippets
* `Alt-Space` - Execute a snippet, which may or may not be highlighted
Snippets are similar to scripts, however, the results are injected into the editor instead of being displayed as query results. You can also add your own custom snippets to `~/.qsh/clients/psql/snippets` for `postgresql`, for example.
![Snippets](images/qsh-snippets.gif)
The snippets currently available are:
* General
+ `columns()` - Get a comma-separated list of column names for a particular table* Scripting
+ `script-function()` - Script out a function
+ `script-procedure()` - Script out a procedure
+ `script-table()` - Script out a table
+ `script-trigger()` - Script out a trigger
+ `script-view()` - Script out a view**Note: When scripting tables for `postgresql`, the invocation of `psql` must be passed to `pg_dump`. If the invocation involves typing in a password, you will be prompted to enter it. For this reason, it may be better to [register a connection](https://github.com/muhmud/qsh/#registering-connections).**
You can keep your own snippets in separate directories and have `qsh` include them in its search by adding them to the `QSH_SNIPPETS_PATH` environment variable.
#### Named Snippets
* `Alt-t` - Format a SQL statement, which must be highlighted
Similar to named scripts, these snippets take a payload from the editor. Currently, this feature can be used to format a SQL statement.
### Registering Connections
You can register connections for database servers that you access frequently. This can also be used to store the password for the connection using the native mechanism of each SQL client. This is achieved using the `qsh-reg` tool, and connection data will be stored under `~/.qsh/connections`.
For example:
```
$ qsh-reg -p dev-server psql -hmy-dev-server -Uroot -ddevdb
```This will register a connection called `dev-server` using the provided `psql` invocation. The `-p` option means that a password is to be stored, which the script will prompt you for.
Once the connection is registered, you can connect like this:
```
$ qsh dev-server
```Execute `qsh-reg` without any arguments to see all the available options.
#### Organising Connections
Connections can also be organised into directories to any level of depth:
```
$ qsh-reg -p production/prod-db psql -h ...
$ qsh-reg -p test/accounting/test-db mysql -h ...
```You would connect just as before:
```
$ qsh production/prod-db
```#### Using Other Database Tools
You can also execute other tools using the connection info, such as `pg_dump`, using the `-c` option:
```
$ qsh -c pg_dump dev-server --table=public.some_table -s
```## Options
The following environment variables can be changed if required:
* `QSH_EDITOR` - The editor you are going to be using, which defaults to `$VISUAL`
* `QSH_PAGER` - The pager you will be using, which by default will try `pspg`, `less`, and `cat` in that order.
* `QSH_SCRIPTS_PATH` - Additional directories, separated by `:`, to search for scripts in
* `QSH_SNIPPETS_PATH` - Additional directories, separated by `:`, to search for snippets in
* `QSH_STARTUP_MODE` - If set to `1`, will make the `-s` option the default, and always startup the editor automatically## Using SSH
To work with database servers over SSH, you should install `qsh` on your remote host and start `tmux` in your SSH session. You won't, however, be able to get `qsh` to work when the editor is running locally and the SQL client is on a remote server, i.e. running within an SSH connection.
If possible, it might be easier to simply provide host and port connection details to the SQL client on your workstation and run everything locally.
## Updating
You can update your local copy like this:
```
$ git -C ~/.qsh pull --rebase
```If you're using the `micro` editor, you will also need to update the editor plugin:
```
$ cp -r ~/.qsh/editors/micro/* ~/.config/micro/plug/qsh/.
```## Exit
To clean up any temporary files & go back to normal, simply exit the editor. If you exit accidentally, just trigger the editor again, and it should go back to how it was.
You can also explicitly cleanup temporary files created by `qsh` by executing:
```
$ qsh-cleanup
```