Skip to main content

web-based sqlite database browser

Project description

sqlite-web is a web-based SQLite database browser written in Python.

Project dependencies:

Installation

$ pip install sqlite-web

Usage

$ sqlite_web /path/to/database.db

If you have multiple databases:

$ sqlite_web /path/to/db1.db /path/to/db2.db /path/to/db3.db

Or run with docker:

$ docker run -it --rm \
    -p 8080:8080 \
    -v /path/to/your-data:/data \
    ghcr.io/coleifer/sqlite-web:latest \
    db_filename.db

Or run with the high-performance gevent WSGI server (requires gevent):

$ sqlite_wsgi /path/to/db.db

Then navigate to http://localhost:8080/ to view your database.

Features

  • Works with your existing SQLite databases, or can be used to create new databases.
  • Add or drop:
    • Tables
    • Columns (with support for older versions of Sqlite)
    • Indexes
  • Export data as JSON or CSV.
  • Import JSON or CSV files.
  • Browse table data.
  • Insert, Update or Delete rows.
  • Load and unload databases at run-time (see --enable-load or --enable-filesystem)

Screenshots

The index page shows some basic information about the database, including the number of tables and indexes, as well as its size on disk:

The structure tab displays information about the structure of the table, including columns, indexes, triggers, and foreign keys (if any exist). From this page you can also create, rename or drop columns and indexes.

Columns are easy to add, drop or rename:

The content tab displays all the table data. Links in the table header can be used to sort the data:

The query tab allows you to execute arbitrary SQL queries on a table. The query results are displayed in a table and can be exported to either JSON or CSV:

The import tab supports importing CSV and JSON files into a table. There is an option to automatically create columns for any unrecognized keys in the import file:

The export tab supports exporting all, or a subset, of columns:

Basic INSERT, UPDATE and DELETE queries are supported:

When configured with --enable-load or --enable-filesystem additional databases can be loaded or unloaded at run-time:

Command-line options

The syntax for invoking sqlite-web is:

$ sqlite_web [options] /path/to/database.db /path/to/another.db

The following options are available:

  • -p, --port: default is 8080
  • -H, --host: default is 127.0.0.1
  • -d, --debug: default is false
  • -l, --log-file: filename for application logs.
  • -q, --quiet: only log errors.
  • -b, --browser: open a web-browser when sqlite-web starts.
  • -x, --no-browser: do not open a web-browser when sqlite-web starts.
  • -P, --password: prompt for password to access sqlite-web. Alternatively, the password can be stored in the "SQLITE_WEB_PASSWORD" environment variable, in which case the application will not prompt for a password, but will use the value from the environment.
  • -r, --read-only: open database in read-only mode.
  • -R, --rows-per-page: set pagination on content page, default 50 rows.
  • -Q, --query-rows-per-page: set pagination on query page, default 1000 rows.
  • -T, --no-truncate: disable ellipsis for long text values. If this option is used, the full text value is always shown.
  • -B, --base64: BLOB data as base64 (default is hex).
  • -e, --extension: path or name of loadable extension(s). To load multiple extensions, specify -e [path] for each extension.
  • -s, --startup-hook: path to a startup hook used to initialize the connection before each request, e.g. my.module.some_callable. Should accept one parameter, the SqliteDatabase instance.
  • -f, --foreign-keys: enable foreign-key constraint pragma.
  • -u, --url-prefix: URL prefix for application, e.g. "/sqlite-web".
  • -L, --enable-load: Enable loading additional databases at runtime (upload only). For adding local databases use --enable-filesystem.
  • -U, --upload-dir: Destination directory for uploaded database (-L). If not specified, a system tempdir will be used.
  • -F, --enable-filesystem: Enable loading additional databases by specifying on-disk path at runtime. Be careful with this.
  • -c, --cert and -k, --key - specify SSL cert and private key.
  • -a, --ad-hoc - run using an ad-hoc SSL context.

Using docker

A Dockerfile is provided with sqlite-web. To use:

#
# Use GitHub container registry:
#

$ docker run -it --rm \
    -p 8080:8080 \
    -v /path/to/your-data:/data \
    ghcr.io/coleifer/sqlite-web:latest \
    db_filename.db

#
# OR build the image yourself:
#

$ cd docker/  # Change dirs to the dir containing Dockerfile
$ docker build -t coleifer/sqlite-web .
$ docker run -it --rm \
    -p 8080:8080 \
    -v /path/to/your-data:/data \
    coleifer/sqlite-web
    db_filename.db

Command-line options can be passed in when running via Docker. For example, if you want to run it at a separate URL prefix, for example /sqlite-web/:

$ docker run -it --rm \
    -p 8080:8080 \
    -v /path/to/your-data:/data \
    ghcr.io/coleifer/sqlite-web:latest \
    db_filename.db \
    --url-prefix="/sqlite-web/"

High-performance WSGI Server

To run sqlite-web with a high-performance gevent WSGI server, you can run sqlite_wsgi instead of sqlite_web:

$ sqlite_wsgi /path/to/db.db

More complete example:

$ sqlite_wsgi -p 8000 -H '0.0.0.0' /path/to/db1.db /path/to/db2.db

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

sqlite_web-0.7.2.tar.gz (773.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sqlite_web-0.7.2-py3-none-any.whl (781.4 kB view details)

Uploaded Python 3

File details

Details for the file sqlite_web-0.7.2.tar.gz.

File metadata

  • Download URL: sqlite_web-0.7.2.tar.gz
  • Upload date:
  • Size: 773.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sqlite_web-0.7.2.tar.gz
Algorithm Hash digest
SHA256 01a2df9a01d65de575edcb85395cff4d8baba19944d2d7e55eb53fab585e7e60
MD5 bb11aace5d4cba1876af93d81142f3f3
BLAKE2b-256 65bcfff204beb859d43dd5324f73f988afe401afd8b02dab80f4b1d143ab1011

See more details on using hashes here.

File details

Details for the file sqlite_web-0.7.2-py3-none-any.whl.

File metadata

  • Download URL: sqlite_web-0.7.2-py3-none-any.whl
  • Upload date:
  • Size: 781.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sqlite_web-0.7.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b3124e803ca7d255b86d1fe9e7c76acc4397164093b64906a73538b7563d27c7
MD5 ae610717273533b9af8c04cb62e57bac
BLAKE2b-256 36d9b3cb53b243c589544a32cf28caa16151b9473abe7eabe995b4508d6a4ee8

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page