MCPcopy
hub / github.com/jorgerojas26/lazysql

github.com/jorgerojas26/lazysql @v0.5.5 sqlite

repository ↗ · DeepWiki ↗ · release v0.5.5 ↗
938 symbols 2,746 edges 71 files 187 documented · 20%
README

[![Contributors][contributors-shield]][contributors-url] [![Forks][forks-shield]][forks-url] [![Stargazers][stars-shield]][stars-url] [![Issues][issues-shield]][issues-url] [![MIT License][license-shield]][license-url] [![LinkedIn][linkedin-shield]][linkedin-url]

LAZYSQL

    A cross-platform TUI database management tool written in Go.

Table of Contents

  1. About The Project
  2. Features
  3. Getting Started
  4. Usage
  5. Commands
  6. Environment variables
  7. Keybindings
  8. Roadmap
  9. Contributing
  10. License
  11. Contact
  12. Acknowledgments

About The Project

![Product Name Screen Shot][product-screenshot1] ![Product Name Screen Shot][product-screenshot2]

This project is heavily inspired by Lazygit, which I think is the best TUI client for Git.

I wanted to have a tool like that, but for SQL. I didn't find one that fits my needs, so I created one myself.

I live in the terminal, so if you are like me, this tool can become handy for you too.

This is my first Open Source project, also, this is my first Go project. I am not a brilliant programmer. I am just a typical JavaScript developer that wanted to learn a new language, I also wanted a TUI SQL Client, so blanca y en botella, leche! (white and bottled).

This project is in ALPHA stage, please feel free to complain about my spaghetti code.

I use Lazysql daily in my full-time job as a full-stack javascript developer in its current (buggy xD) state. So, the plan is to improve and fix my little boy as a side-project in my free time.

Built With

![Golang][golang-shield] ![Golang][tview-shield]

Features

  • [x] Cross-platform (macOS, Windows, Linux)
  • [x] Vim Keybindings
  • [x] Can manage multiple connections (Backspace)
  • [x] Tabs
  • [x] SQL Editor (CTRL + e)

Getting Started

Installation

Homebrew (macOS/Linux)

brew install lazysql

Install with go package manager

go install github.com/jorgerojas26/lazysql@latest

Binary Releases

For Windows, macOS or Linux, you can download a binary release here

Third party (maintained by the community)

Arch Linux users can install it from the AUR with:

paru -S lazysql

or

yay -S lazysql

or install it manual with:

git clone https://aur.archlinux.org/lazysql.git
cd lazysql
makepkg -si

(back to top)

Configuration

If the XDG_CONFIG_HOME environment variable is set, the configuration file will be located at:

  • ${XDG_CONFIG_HOME}/lazysql/config.toml

If not, the configuration file will be located at:

  • Windows: %APPDATA%\lazysql\config.toml
  • macOS: ~/Library/Application Support/lazysql/config.toml
  • Linux: ~/.config/lazysql/config.toml

The configuration file is a TOML file and can be used to define multiple connections.

Example configuration

[[database]]
Name = 'Production database'
Provider = 'postgres'
DBName = 'foo'
URL = 'postgres://${user}:urlencodedpassword@localhost:${port}/foo'
ReadOnly = true
Commands = [
  { Command = 'ssh -tt remote-bastion -L ${port}:localhost:5432', WaitForPort = '${port}' },
  { Command = 'whoami', SaveOutputTo = 'user' },
]
[[database]]
Name = 'Development database'
Provider = 'postgres'
DBName = 'foo'
URL = 'postgres://postgres:urlencodedpassword@localhost:5432/foo'
[application]
DefaultPageSize = 300
DisableSidebar = false
SidebarOverlay = false
JSONViewerWordWrap = false
EnterOpensJSONViewer = false

The ReadOnly field (optional, defaults to false) can be set to true to enable read-only mode for a connection. When enabled, all mutation queries (INSERT, UPDATE, DELETE, DROP, etc.) will be blocked.

The [application] section is used to define some app settings. Not all settings are available yet, this is a work in progress.

Application settings

Setting Default Description
DefaultPageSize 300 Number of records to fetch per page
DisableSidebar false Disable the sidebar
SidebarOverlay false Show sidebar as overlay instead of side panel
JSONViewerWordWrap false Enable word wrap in JSON viewer
EnterOpensJSONViewer false Open JSON viewer when pressing Enter on a cell

Local Configuration

You can place a .lazysql.toml file in your project directory (next to your .git folder) to override the global configuration for that project. This is useful for defining project-specific database connections or settings.

lazysql searches for .lazysql.toml by walking up from the current working directory. It stops at the git repository root (where .git is found). If no local config is found, the global configuration is used as-is.

Merge behavior:

Section Behavior
[application] Deep merge — local values override global, unset fields keep global/defaults
[[database]] Replace — local connections completely replace global connections
[keymap.*] Deep merge — local keybindings override global ones for the same command

Example .lazysql.toml:

[application]
DefaultPageSize = 500

[[database]]
Name = 'Local development'
Provider = 'postgres'
URL = 'postgres://localhost/myproject_dev'

With this local config, DefaultPageSize overrides the global value, and only the Local development connection is available (global connections are replaced).

Environment variables (${env:VAR_NAME}) work in local config files just like in the global config.

Note: When a local .lazysql.toml is found, the full config is saved to the local file when you modify connections from the UI.

Usage

For a list of keyboard shortcuts press ?

Open the TUI with:

$ lazysql

To launch lazysql with the ability to pick from the saved connections.

$ lazysql [connection_url]

To launch lazysql and connect to database at [connection_url].

$ lazysql --read-only [connection_url]

To launch lazysql in read-only mode.

Connect to a DB

  1. Start lazysql
  2. Create a new connection (press n)
  3. Provide a name for the connection as well as the URL to connect to (see example connection URL)
  4. Connect to the DB (press <Enter>)

If you already have a connection set up: 1. Start lazysql 2. Select the right connection (press j and h for navigation) 3. Connect to the DB (press c or <Enter>)

Create a table

There is currently no way to create a table from the TUI. However you can run the query to create the table as a SQL-Query, inside the SQL Editor.

You can update the tree by pressing R, so you can see your newly created table.

Execute SQL queries

  1. Press <Ctrl+E> to open the built-in SQL Editor
  2. Write the SQL query
  3. Press <Ctrl+R> to execute the SQL query

To switch back to the table-tree press H

After executing a SELECT-query a table will be displayed under the SQL-Editor with the query-result. \ To switch focus back to SQL-Editor press /

Open/view a table

  1. Expand the table-tree by pressing e or <Enter>
  2. Select the table you want to view
    • next node j
    • previous node k
    • last node G
    • first node g
  3. Press <Enter> to open the table

To switch back to the table-tree press H \ To switch back to the table press L

Filter rows

  1. Open a table
  2. Press / to focus the filter input
  3. Write a WHERE-clause to filter the table
  4. Press <Enter> to submit your filter

To remove the filter, focus the filter input (press /) and press <Esc>.

Insert a row

  1. Open a table
  2. Press 1 to switch to the record tab
  3. Press o to insert a new row
  4. Fill out all columns
  5. Press <Ctrl+S> to save the changes

Edit a column

  1. Open a table
  2. Press 1 to switch to the record tab
  3. Move to the column you want to edit
  4. Press c to edit, Press <Enter> to submit
  5. Press <Ctrl+S> to save the changes

Export to CSV

From Table View

  1. Open a table
  2. Apply filters or sorting as needed
  3. Press E to open the export dialog
  4. Optionally modify the file path and batch size
  5. Select export scope:
  6. Export Current Page: Export only the currently displayed rows
  7. Export All Records: Fetch and export all records from the table

Batch size (default: 10000): When exporting all records, data is fetched in batches to avoid timeout or memory issues with large tables. Increase for faster exports, decrease if you encounter any errors.

The default file path is ~/Downloads/{database}_{table}_{timestamp}.csv.

From SQL Editor

  1. Execute a SQL query
  2. Press E to open the export dialog
  3. Optionally modify the file path
  4. Select Export to save all query results

(back to top)

Support

  • [x] MySQL
  • [x] PostgreSQL
  • [x] SQLite
  • [x] MSSQL
  • [ ] MongoDB

Support for multiple RDBMS is a work in progress.

Commands

In some cases, mostly when connecting to remote databases, it might be necessary to run a custom command before being able to connect to the database. For example when you can only access the database through a remote bastion, you would probably first need to open an SSH tunnel by running the following command in a separate terminal:

ssh remote-bastion -L 5432:localhost:5432

In order to make it easier to run these commands, lazysql supports running custom commands before connecting to the database. You can define these commands in the configuration file like this:

[[database]]
Name = 'server'
Provider = 'postgres'
DBName = 'foo'
URL = 'postgres://${user}:password@localhost:${port}/foo'
Commands = [
  { Command = 'ssh -tt remote-bastion -L ${port}:localhost:5432', WaitForPort = '${port}' },
  { Command = 'whoami', SaveOutputTo = 'user' },
]

The Command field is required and can contain any command that you would normally run in your terminal. The WaitForPort field is optional and can be used to wait for a specific port to be open before continuing. The SaveOutputTo field is optional and can be used to make user-defined variables. The output (stdout) from the command will be saved into the variable, and the variable can be used in the URL or future commands via the ${VARIABLE} syntax.

When you define the ${port} variable in the URL field, lazysql will automatically replace it with a random free port number. This port number will then be used in the connection URL and is available in the Commands field so that you can use it to configure the command.

You can even chain commands to, for example, connect to a remote server and then to a postgres container running in a remote k8s cluster:

[[database]]
Name = 'container'
Provider = 'postgres'
DBName = 'foo'
URL = 'postgres://postgres:password@localhost:${port}/foo'
Commands = [
  { Command = 'ssh -tt remote-bastion -L 6443:localhost:6443', WaitForPort = '6443' },
  { Command = 'kubectl port-forward service/postgres ${port}:5432 --kubeconfig /path/to/kube.conf', WaitForPort = '${port}' }
]

Environment variables

You can use environment variables in the configuration file using the ${env:VAR_NAME} syntax. This is useful for keeping sensitive information like passwords out of the configuration file.

[[database]]
Name = 'Production'
Provider = 'postgres'
URL = 'postgres://${env:DB_USER}:${env:DB_PASSWORD}@localhost:5432/mydb'
export DB_USER=admin
export DB_PASSWORD=secret
lazysql

Note: Undefined environment variables will be replaced with an empty string.

Keybindings

Custom Keybindings

You can customize keybindings by adding a [keymap.<Group>] section to your config.toml file. Each entry maps a command name to a key.

[keymap.Home]
SwitchToEditorView = "i"
Quit = "Esc"

[keymap.Tree]
GotoTop = "t"
Search = "Ctrl-F"

For single character keys, use the character directly (e.g., "q", "G", "1", "/"). For special keys, use the tcell key name (e.g., "Enter", "Esc", "Ctrl-S"). Only key names defined in tcell are supported.

Group names are case-insensitive (Home, home, and HOME all work).

Available groups: Home, Connection, Tree, TreeFilter, Table, Editor, Sidebar, QueryPreview, QueryHistory, JSONViewer.

Default Keybindings

Home

Default Key Command Description
L MoveRight Focus table
H MoveLeft Focus tree
Ctrl-E SwitchToEditorView Open SQL editor
Ctrl-S Save Execute pending changes

Extension points exported contracts — how you extend this code

Driver (Interface)
(no doc) [6 implementers]
drivers/driver.go
TabContent (Interface)
(no doc) [5 implementers]
components/tabbed_menu.go

Core symbols most depended-on inside this repo

SetText
called by 87
components/sql_editor.go
GetText
called by 64
components/sql_editor.go
Run
called by 55
app/app.go
SetFocus
called by 52
components/results_table_menu.go
formatTableName
called by 52
drivers/mysql.go
Error
called by 34
helpers/logger/logger.go
String
called by 30
components/sql_editor.go
pushUndo
called by 22
components/sql_editor.go

Shape

Method 542
Function 304
Struct 81
TypeAlias 9
Interface 2

Languages

Go100%

Modules by API surface

components/results_table.go96 symbols
components/sql_editor.go69 symbols
components/tree_test.go53 symbols
components/tree.go38 symbols
drivers/postgres.go37 symbols
drivers/utils_test.go35 symbols
drivers/mysql_test.go35 symbols
drivers/mssqql.go35 symbols
components/sql_context_test.go34 symbols
drivers/sqlite.go32 symbols
drivers/mysql.go32 symbols
drivers/driver.go31 symbols

Dependencies from manifests, versioned

filippo.io/edwards25519v1.1.0 · 1×
github.com/Azure/azure-sdk-for-go/sdk/azcorev1.11.1 · 1×
github.com/Azure/azure-sdk-for-go/sdk/azidentityv1.6.0 · 1×
github.com/Azure/azure-sdk-for-go/sdk/internalv1.8.0 · 1×
github.com/AzureAD/microsoft-authentication-library-for-gov1.2.2 · 1×
github.com/BurntSushi/tomlv1.5.0 · 1×
github.com/DATA-DOG/go-sqlmockv1.5.2 · 1×
github.com/atotto/clipboardv0.1.4 · 1×
github.com/dustin/go-humanizev1.0.1 · 1×
github.com/gdamore/encodingv1.0.1 · 1×

Datastores touched

(mysql)Database · 1 repos
dbnameDatabase · 1 repos
mydbDatabase · 1 repos
dbDatabase · 1 repos
dbnameDatabase · 1 repos
fooDatabase · 1 repos
mydbDatabase · 1 repos
myproject_devDatabase · 1 repos

For agents

$ claude mcp add lazysql \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact