The table list buffer

The table list buffer is the main PGmacs buffer. It shows some metainformation concerning the PostgreSQL backend that you are connected to (version, database size on disk, etc.), followed by a tabulated list of all the tables in the database (at least the tables which are visible to your current PostgreSQL user).

Screenshot table list

The following keys are bound when the point is located in the table list buffer:

KeyBinding
RETOpen a new buffer to browse/edit the table at point.
DelDelete the table at point.
RRename the table at point.
oPrompt for a table to browse/edit in a new buffer.
pNew buffer listing the functions and procedures in the current database.
eOpen a new buffer to display the output from an SQL query.
EExecute SQL from an Emacs buffer and display the output.
SRun SchemaSpy on the current database and display the SVG output.
<Move to the beginning of the table list.
>Move to the end of the table list.
{Make the current column narrower.
}Make the current column wider.
gRedraw the current buffer (refetches data from PostgreSQL).
hDisplay help for the table-list buffer.
qBury the current buffer.

The More backend information button will open a buffer that displays further information concerning the PostgreSQL backend that you are connected to, including the list of available extensions.

Screenshot backend information

Custom buttons in the table-list buffer

The list of buttons displayed above the list of tables (“Display tables“, “More backend information” and so on) is user-customizable via the variable pgmacs-table-list-buttons. To add a new button to this list, add code such as the following to your Emacs initialization file:

(require 'pgmacs)

(add-to-list 'pgmacs-table-list-buttons
   (pgmacs-shortcut-button
     :label "The displayed label"
     :action #'my/function-of-zero-arguments
     :help-echo "Help text echoed to minibuffer"))

If you prefer the button to be added to the end of the list, add a last argument of t to the add-to-list invocation.