Database
Database MCP server for MySQL, MariaDB, PostgreSQL & SQLite
Database MCP
A single-binary MCP server for SQL databases. Connect your AI assistant to MySQL/MariaDB, PostgreSQL, or SQLite with zero runtime dependencies.
Website · Documentation · Releases

Features
- Multi-database — MySQL/MariaDB, PostgreSQL, and SQLite from one binary
- 6 MCP tools —
list_databases,list_tables,get_table_schema,read_query,write_query,create_database - Single binary — ~7 MB, no Python/Node/Docker needed
- Multiple transports — stdio (for Claude Desktop, Cursor) and HTTP (for remote/multi-client)
- Two-layer config — CLI flags > environment variables, with sensible defaults per backend
Quick Start
Using .mcp.json (recommended)
Add a .mcp.json file to your project root. MCP clients read this file and configure the server automatically.
Stdio transport — the client starts and manages the server process:
{
"mcpServers": {
"database-mcp": {
"command": "database-mcp",
"env": {
"DB_BACKEND": "mysql",
"DB_HOST": "127.0.0.1",
"DB_PORT": "3306",
"DB_USER": "root",
"DB_PASSWORD": "secret",
"DB_NAME": "mydb"
}
}
}
}
HTTP transport — you start the server yourself, the client connects to it:
# Start the server first
database-mcp http --db-backend mysql --db-user root --db-name mydb --port 9001
{
"mcpServers": {
"database-mcp": {
"type": "http",
"url": "http://127.0.0.1:9001/mcp"
}
}
}
Note: The
"type": "http"field is required for HTTP transport. Without it, clients like Claude Code will reject the config.
Using CLI flags
# MySQL/MariaDB
database-mcp --db-backend mysql --db-host localhost --db-user root --db-name mydb
# PostgreSQL
database-mcp --db-backend postgres --db-host localhost --db-user postgres --db-name mydb
# SQLite
database-mcp --db-backend sqlite --db-name ./data.db
# HTTP transport
database-mcp http --db-backend mysql --db-user root --db-name mydb --host 0.0.0.0 --port 9001
Using environment variables
DB_BACKEND=mysql DB_USER=root DB_NAME=mydb database-mcp
Configuration
Configuration is loaded with clear precedence:
CLI flags > environment variables > defaults
Environment variables are typically set by your MCP client (via env or envFile in the server config).
Subcommands
| Subcommand | Description |
|---|---|
stdio | Run in stdio mode (default if no subcommand given) |
http | Run in HTTP/SSE mode |
Database Options (shared across subcommands)
| Flag | Env Variable | Default | Description |
|---|---|---|---|
--db-backend | DB_BACKEND | (required) | mysql, mariadb, postgres, or sqlite |
--db-host | DB_HOST | localhost | Database host |
--db-port | DB_PORT | backend default | 3306 (MySQL/MariaDB), 5432 (PostgreSQL) |
--db-user | DB_USER | backend default | root (MySQL/MariaDB), postgres (PostgreSQL) |
--db-password | DB_PASSWORD | (empty) | Database password |
--db-name | DB_NAME | (empty) | Database name or SQLite file path |
--db-charset | DB_CHARSET | Character set (MySQL/MariaDB only) |
SSL/TLS Options
| Flag | Env Variable | Default | Description |
|---|---|---|---|
--db-ssl | DB_SSL | false | Enable SSL |
--db-ssl-ca | DB_SSL_CA | CA certificate path | |
--db-ssl-cert | DB_SSL_CERT | Client certificate path | |
--db-ssl-key | DB_SSL_KEY | Client key path | |
--db-ssl-verify-cert | DB_SSL_VERIFY_CERT | true | Verify server certificate |
Server Options
| Flag | Env Variable | Default | Description |
|---|---|---|---|
--read-only | MCP_READ_ONLY | true | Block write queries |
--max-pool-size | MCP_MAX_POOL_SIZE | 10 | Max connection pool size (min: 1) |
Logging Options
| Flag | Env Variable | Default | Description |
|---|---|---|---|
--log-level | LOG_LEVEL | info | Log level (trace/debug/info/warn/error) |
HTTP-only Options (only available with http subcommand)
| Flag | Default | Description |
|---|---|---|
--host | 127.0.0.1 | Bind host |
--port | 9001 | Bind port |
--allowed-origins | localhost variants | CORS allowed origins (comma-separated) |
--allowed-hosts | localhost,127.0.0.1 | Trusted Host headers (comma-separated) |
MCP Tools
list_databases
Lists all accessible databases. Returns a JSON array of database names. Not available for SQLite.
list_tables
Lists all tables in a database. Parameters: database_name.
get_table_schema
Returns column definitions (type, nullable, key, default, extra) and foreign key relationships (constraint name, referenced table/column, on update/delete rules) for a table. Parameters: database_name, table_name.
read_query
Executes a read-only SQL query (SELECT, SHOW, DESCRIBE, USE, EXPLAIN). Always enforces SQL validation as defence-in-depth. Parameters: sql_query, database_name.
write_query
Executes a write SQL query (INSERT, UPDATE, DELETE, CREATE, ALTER, DROP). Only available when read-only mode is disabled. Parameters: sql_query, database_name.
create_database
Creates a database if it doesn't exist. Only available when read-only mode is disabled. Not available for SQLite. Parameters: database_name.
Security
- Read-only mode (default) — write tools hidden from AI assistant;
read_queryenforces AST-based SQL validation - Single-statement enforcement — multi-statement injection blocked at parse level
- Dangerous function blocking —
LOAD_FILE(),INTO OUTFILE,INTO DUMPFILEdetected in the AST - Identifier validation — database/table names validated against control characters and empty strings
- CORS + trusted hosts — configurable for HTTP transport
- SSL/TLS — configured via individual
DB_SSL_*variables - Credential redaction — database password is never shown in logs or debug output
Testing
# Unit tests
cargo test --lib
# Integration tests (requires Docker)
./tests/run.sh
# Filter by engine
./tests/run.sh --filter mariadb
./tests/run.sh --filter mysql
./tests/run.sh --filter postgres
./tests/run.sh --filter sqlite
# With MCP Inspector
npx @modelcontextprotocol/inspector ./target/release/database-mcp
# HTTP mode testing
curl -X POST http://localhost:9001/mcp \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"jsonrpc":"2.0","id":1,"method":"initialize","params":{"protocolVersion":"2024-11-05","capabilities":{},"clientInfo":{"name":"test","version":"0.1"}}}'
Project Structure
This is a Cargo workspace with the following crates:
| Crate | Path | Description |
|---|---|---|
database-mcp | . (root) | Main binary — CLI, transports, database backends |
database-mcp-backend | crates/backend/ | Shared error types, validation, and identifier utilities |
database-mcp-config | crates/config/ | Configuration structs and CLI argument mapping |
database-mcp-server | crates/server/ | Shared MCP tool implementations and server info |
database-mcp-mysql | crates/mysql/ | MySQL/MariaDB backend handler and operations |
database-mcp-postgres | crates/postgres/ | PostgreSQL backend handler and operations |
database-mcp-sqlite | crates/sqlite/ | SQLite backend handler and operations |
sqlx-to-json | crates/sqlx-to-json/ | Type-safe row-to-JSON conversion for sqlx (RowExt trait) |
Development
cargo build # Development build
cargo build --release # Release build (~7 MB)
cargo test # Run tests
cargo clippy --workspace --tests -- -D warnings # Lint
cargo fmt # Format
cargo doc --no-deps # Build documentation
License
This project is licensed under the MIT License — see the LICENSE file for details.
相关服务器
Property Comps MCP Server
Property comparable sales data across 11 global markets (UK, France, NYC, Singapore, Dubai + 6 more). 4.2M+ government-sourced transactions.
Graphiti MCP Server
A framework for building and querying temporally-aware knowledge graphs for AI agents.
MySQL
A server for managing MySQL databases.
Engram
Persistent memory layer for AI agents with semantic search, consolidation, and cross-session intelligence via MCP.
Lerian MCP Memory Server
A server providing persistent memory for AI assistants, with support for multiple AI providers.
Alpha Vantage
Provides real-time financial market data using the Alpha Vantage API.
Video Metadata MCP Server
Manages video metadata, including game information, teams, scores, and other sports-related data.
Metabase MCP Server
Interact with Metabase, the open-source business intelligence platform, using Large Language Models.
Mongo
A Model Context Protocol (MCP) server that enables LLMs to interact directly with MongoDB databases
MongoDB That Works
A MongoDB MCP server with schema discovery and field validation. Requires a MONGODB_URI environment variable.