👉 Support this work via GitHub Sponsors
An experimental package to extend Emacs 29’s sqlite-mode.
I’ve received enough requests to put this on MELPA from folks that have found the package stable and helpful.
Having said that, I want to be upfront that I haven’t tested the code thoroughly, so please use at own risk (please back up your database).
Once the package is on MELPA, you’ll be able to install via:
(use-package sqlite-mode-extras
:bind (:map
sqlite-mode-map
("n" . next-line)
("p" . previous-line)
("b" . sqlite-mode-extras-backtab-dwim)
("f" . sqlite-mode-extras-tab-dwim)
("+" . sqlite-mode-extras-add-row)
("D" . sqlite-mode-extras-delete-row-dwim)
("C" . sqlite-mode-extras-compose-and-execute)
("E" . sqlite-mode-extras-execute)
("S" . sqlite-mode-extras-execute-and-display-select-query)
("DEL" . sqlite-mode-extras-delete-row-dwim)
("g" . sqlite-mode-extras-refresh)
("<backtab>" . sqlite-mode-extras-backtab-dwim)
("<tab>" . sqlite-mode-extras-tab-dwim)
("RET" . sqlite-mode-extras-ret-dwim)))sqlite-mode-extras-tab-dwim: Tab navigation.
sqlite-mode-extras-ret-dwim: Edit field.
sqlite-mode-extras-compose-and-execute: Compose and execute a query.
sqlite-mode-extras-execute: Execute a query.
sqlite-mode-extras-add-row: Add row to table at point.
sqlite-mode-extras-delete-row-dwim: Similar tosqlite-mode-deletebut also enables deleting range in region.
sqlite-mode-extras-refresh: Refreshes the buffer re-querying the database.sqlite-mode-extras-ret-dwim: If on table, toggle expansion. If on row, edit it.sqlite-mode-extras-execute-and-display-select-query: Executes a query and displays results.
I’ve been playing with the following key bindings:
👉 Find this useful? Support this work via GitHub Sponsors







