MariaDB MCP Server
Enables AI assistants to interact with MariaDB databases through schema exploration, query execution, and database statistics. Includes security features like read-only mode, parameterized queries, and connection pooling with support for both JSON and Markdown output formats.
README
MariaDB MCP Server
A powerful Model Context Protocol (MCP) server that enables AI assistants like Claude to interact with your MariaDB databases. This server provides comprehensive database access with schema exploration, query execution, and advanced features.
Features
- 🔍 Schema Exploration: Browse databases, tables, and detailed schema information
- 📊 Query Execution: Execute both read-only and write queries (configurable)
- 📄 Multiple Output Formats: JSON for programmatic use, Markdown for human readability
- 📑 Pagination Support: Handle large result sets efficiently
- 🔒 Security Features: Parameterized queries, SQL injection prevention, read-only mode
- 🏊 Connection Pooling: Efficient database connection management
- ⚡ Performance: Query timeouts, result size limits, and optimized response formatting
Installation
Prerequisites
- Python 3.8+ installed on your system
- MariaDB Connector/C (required for the Python MariaDB connector)
Installing MariaDB Connector/C
On macOS:
brew install mariadb-connector-c
export MARIADB_CONFIG=$(brew --prefix mariadb-connector-c)/bin/mariadb_config
On Ubuntu/Debian:
sudo apt-get update
sudo apt-get install libmariadb-dev
On RHEL/CentOS/Fedora:
sudo yum install mariadb-connector-c-devel
On Windows: Download and install from MariaDB Connector/C downloads
Install Dependencies
pip install -r requirements.txt
Or install packages individually:
pip install mcp mariadb
Configuration
Environment Variables
Configure the server using these environment variables:
# Required - Database Connection
export MARIADB_HOST="localhost" # Database server hostname
export MARIADB_PORT="3306" # Database server port
export MARIADB_USER="your_username" # Database username
export MARIADB_PASSWORD="your_password" # Database password
export MARIADB_DATABASE="" # Default database (optional)
# Optional - Security & Performance
export MARIADB_READ_ONLY="true" # Set to "false" to allow write queries
export MARIADB_POOL_SIZE="5" # Connection pool size (default: 5)
Claude Desktop Configuration
Add this to your Claude Desktop configuration file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
Linux: ~/.config/Claude/claude_desktop_config.json
{
"mcpServers": {
"mariadb": {
"command": "python",
"args": ["/path/to/mariadb_mcp_server.py"],
"env": {
"MARIADB_HOST": "localhost",
"MARIADB_PORT": "3306",
"MARIADB_USER": "your_username",
"MARIADB_PASSWORD": "your_password",
"MARIADB_DATABASE": "your_database",
"MARIADB_READ_ONLY": "true"
}
}
}
}
Alternative: Using uvx (Recommended for easy updates)
If you package and publish the server to PyPI:
{
"mcpServers": {
"mariadb": {
"command": "uvx",
"args": ["mariadb-mcp-server"],
"env": {
"MARIADB_HOST": "localhost",
"MARIADB_PORT": "3306",
"MARIADB_USER": "your_username",
"MARIADB_PASSWORD": "your_password",
"MARIADB_DATABASE": "your_database"
}
}
}
}
Available Tools
The server provides the following tools:
1. list_databases
List all accessible databases on the MariaDB server.
Example usage in Claude:
- "What databases are available?"
- "Show me all databases"
2. list_tables
List all tables in a specific database with metadata.
Parameters:
database_name: Name of the databaseresponse_format: "json" or "markdown" (default: "markdown")
Example usage in Claude:
- "What tables are in the sales database?"
- "List all tables in my_app database"
3. get_table_schema
Get detailed schema information for a specific table.
Parameters:
database_name: Name of the databasetable_name: Name of the tableinclude_indexes: Include index information (default: true)include_foreign_keys: Include foreign key relationships (default: true)response_format: "json" or "markdown"
Example usage in Claude:
- "Show me the schema for the users table"
- "What columns does the orders table have?"
4. execute_query
Execute SQL queries against the database.
Parameters:
database_name: Database to queryquery: SQL query to executeparameters: Query parameters for parameterized queries (optional)limit: Maximum rows to return (default: 100, max: 1000)offset: Number of rows to skip for pagination (default: 0)response_format: "json" or "markdown"
Example usage in Claude:
- "Find all users who registered in the last month"
- "Show me the top 10 selling products"
- "Update the status of order 12345 to 'shipped'"
5. get_database_stats
Get statistics and metadata about a database.
Parameters:
database_name: Name of the databaseresponse_format: "json" or "markdown"
Example usage in Claude:
- "How large is the analytics database?"
- "Show me statistics for the production database"
Security Features
Read-Only Mode
By default, the server runs in read-only mode, allowing only SELECT, SHOW, DESCRIBE, and EXPLAIN queries. To enable write operations:
export MARIADB_READ_ONLY="false"
SQL Injection Prevention
- The server uses parameterized queries
- SQL comments are automatically stripped
- Query validation is performed before execution
Connection Security
- Connection pooling with automatic reconnection
- Configurable timeouts
- Secure credential handling through environment variables
Usage Examples
Once configured, you can interact with your MariaDB database through Claude:
Example 1: Explore Database Structure
You: "What databases do I have access to?"
Claude: [Uses list_databases tool]
You: "Show me the tables in the ecommerce database"
Claude: [Uses list_tables tool]
You: "What's the structure of the customers table?"
Claude: [Uses get_table_schema tool]
Example 2: Query Data
You: "Find the top 5 customers by total purchase amount"
Claude: [Uses execute_query to run an aggregation query]
You: "Show me all orders from last month"
Claude: [Uses execute_query with date filtering]
Example 3: Data Analysis
You: "Analyze the sales trends for Q4"
Claude: [Uses multiple tools to explore schema and run analytical queries]
You: "What's the average order value by product category?"
Claude: [Uses execute_query with GROUP BY and aggregation]
Troubleshooting
Common Issues
- Connection Error: Verify your database credentials and that MariaDB is running
- MariaDB Connector/C Not Found: Ensure you've installed the connector and set MARIADB_CONFIG
- Permission Denied: Check that your database user has appropriate permissions
- Query Timeout: Complex queries may timeout; consider optimizing or increasing timeout
Debug Mode
To enable detailed logging:
# In the server file, change:
logging.basicConfig(level=logging.DEBUG)
Performance Optimization
Best Practices
- Use Indexes: Ensure your tables have appropriate indexes for common queries
- Limit Results: Always use LIMIT clauses for large tables
- Parameterized Queries: Use parameters instead of string concatenation
- Connection Pooling: Adjust MARIADB_POOL_SIZE based on your workload
Response Size Management
- Results are automatically truncated if they exceed 25,000 characters
- Use pagination (limit/offset) for large result sets
- Choose JSON format for programmatic processing, Markdown for readability
Development
Testing the Server
# Test connection
python mariadb_mcp_server.py
# The server will wait for MCP commands on stdin
# Press Ctrl+C to exit
Extending the Server
To add new tools, follow this pattern:
@mcp.tool(
name="your_tool_name",
annotations={
"title": "Human Readable Title",
"readOnlyHint": True,
"destructiveHint": False,
"idempotentHint": True,
"openWorldHint": True
}
)
async def your_tool_function(params: YourInputModel) -> str:
"""Tool documentation"""
# Implementation
pass
License
MIT License - See LICENSE file for details
Support
For issues, questions, or contributions:
- Check the troubleshooting section
- Review environment variable configuration
- Ensure MariaDB Connector/C is properly installed
- Verify database permissions
Changelog
Version 1.0.0 (Current)
- Initial release with core functionality
- Schema exploration tools
- Query execution with pagination
- Multiple output formats
- Security features and connection pooling
Roadmap
- [ ] Transaction support for complex operations
- [ ] Query history and caching
- [ ] Advanced query builder assistance
- [ ] Performance profiling tools
- [ ] Backup and restore utilities
- [ ] Vector search capabilities (MariaDB 11.7+)
Credits
Built with the MCP Python SDK (FastMCP) and MariaDB Connector/Python.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
E2B
Using MCP to run code via e2b.