usql is a universal command-line interface for working with SQL databases.
usql provides a universal command-line interface for the following databases: PostgreSQL, MySQL, Oracle, SQLite, Microsoft SQL Server, Microsoft ADODB (Windows only), and others.
The goal is to eventually have usql be a drop in replacement for PostgreSQL's
psql
command, with all the bells/whistles, but with the added benefit of
working with multiple databases.
Install in the usual Go way:
# install usql
$ go get -u github.com/knq/usql
# install with oracle support
$ go get -u -tags oracle github.com/knq/usql
# install with oracle + adodb support (windows only)
$ go get -u -tags 'oracle adodb' github.com/knq/usql
Alternatively, you can download a binary release for your platform from the GitHub releases page.
usql
makes use of the dburl
package for
opening URLs. Almost every database recognized by dburl
can be opened by
usql
. Some example ways to connect to a database:
# display command line arguments
$ usql --help
# connect to a postgres database
$ usql pg://user:pass@localhost/dbname
$ usql pgsql://user:pass@localhost/dbname
$ usql postgres://user:pass@localhost:port/dbname
# connect to a mysql database
$ usql my://user:pass@localhost/dbname
$ usql mysql://user:pass@localhost:port/dbname
$ usql /var/run/mysqld/mysqld.sock
# connect to a mssql (Microsoft SQL) database
$ usql ms://user:pass@localhost/dbname
$ usql mssql://user:pass@localhost:port/dbname
# connect using Windows domain authentication to a mssql (Microsoft SQL)
# database
$ runas /user:ACME\wiley /netonly "usql mssql://host/dbname/"
# connect to a oracle database
$ usql or://user:pass@localhost/dbname
$ usql oracle://user:pass@localhost:port/dbname
# connect to a sqlite file
$ usql dbname.sqlite3
# note: when not using a "<scheme>://" or "<scheme>:" prefix, the file must already
# exist; if it doesn't, please prefix with file:, sq:, sqlite3: or any other
# scheme alias recognized by the dburl package for sqlite databases, and sqlite
# will create a new database, like the following:
$ usql sq://path/to/dbname.sqlite3
$ usql sqlite3://path/to/dbname.sqlite3
$ usql file:/path/to/dbname.sqlite3
# connect to a adodb ole resource (windows only)
$ usql adodb://Microsoft.Jet.OLEDB.4.0/myfile.mdb
$ usql "adodb://Microsoft.ACE.OLEDB.12.0/?Extended+Properties=\"Text;HDR=NO;FMT=Delimited\""
The following is an example of connecting to xo's booktest example Oracle database, performing a query, and then connecting to the PostgreSQL, MySQL, Microsoft SQL Server, and SQLite3 databases and executing various queries.
- dburl - a Go package providing a standard, URL style mechanism for parsing and opening database connection URLs
- xo - a command-line tool to generate Go code from a database schema
A list of planned / in progress work:
- .usqlpass file (ie .psqlpass)
- Fix meta command parsing when passed a quoted string ie, \echo " foo bar " should have all whitespace included in the parameter
- fix table output / formatting
- Transaction wrapping / starts/commits / "-1" one transaction stuff
- pager + pipe / gexec/gset support
- SQL variables + environment
- add support for managing multiple database connections simultaneously (@conn syntax, and a ~/.usqlconnections file, and ~/.usqlconfig) (maybe not needed, if variable support works "as expected"?)
- SQL completion (WIP)
- syntax highlighting (WIP)
- \encoding and environment/command line options to set encoding of input (to convert to utf-8 before feeding to SQL driver) (how important is this ... ?)
- better --help support/output cli, man pages
- correct operation of interweaved -f/-c commands, ie: -f 1 -c 1 -c 2 -f 2 -f 3 -c 3 runs in the specified order
- PAGER + EDITOR support (WIP)
- variable support / interpolation + \prompt, \set, \unset
- the \j* commands (WIP)
- \watch
- \errverbose
- formatting settings (\pset, \a, etc)
- all \d* commands from
psql
(WIP, need to finish work extracting introspection code fromxo
) - remaining
psql
cli parameters
Need to write scripts for packaging and build binaries for:
- Debian/Ubuntu (.deb)
- MacOS X (.pkg)
- Windows (.msi)
- CentOS/RHEL (.rpm)
Additional:
- Submit upstream to Debian unstable (WIP)
- full test suite for databases, doing a minimal set of SELECT, INSERT, UPDATE, DELETE
Notes / thoughts / comments on adding support for various "databases":
- Google Spanner
- Cassandra
- Atlassian JIRA JQL (why not? lol)