mcp-mysql-server
Provides a lightweight MySQL database interface via stdio, enabling query execution, data manipulation, schema inspection, and connection testing using FastMCP tools.
README
mcp-mysql-server
A simple Python script for interacting with a local MySQL database via standard input/output (stdio), based on FastMCP.
Overview
mcp-mysql-server provides a command-line interface for querying and inspecting the schema of a local MySQL database. It is designed for ease of use in local development environments where a lightweight, script-based interaction is preferred. The script utilizes standard input and output for commands and results, making it easy to integrate with other command-line tools and workflows.
Features
- Query Execution: Execute SQL SELECT statements and view the results in a simple, readable format.
- Data Manipulation: Insert data into tables with the write_table tool.
- Schema Inspection: Retrieve information about the database schema, including:
- Listing all tables with the list_tables tool.
- Displaying the columns and their data types for a specific table with get_table_schema.
- Connection Testing: Test database connectivity and get server information.
- Configurable Access Controls: Define connection parameters (host, user, password, database) through configuration, allowing secure access to the database.
- stdio Interface: Interact with the script using standard input for commands and receive output via standard output, facilitating scripting and automation.
- Local Deployment Focus: Optimized for use within local development environments.
Getting Started
Prerequisites
- Python 3.x installed on your system.
- A local MySQL server instance running.
- Required Python libraries (install using the requirements.txt file):
pip install -r requirements.txt
Installation
- Download or clone the repository to your local machine.
Configuration
-
Create a configuration file (e.g.,
config.ini) in the same directory as the script or specify the path when running the script. The configuration file should have the following format:[mysql] host = localhost port = 3306 # Optional, defaults to 3306 user = your_mysql_user password = your_mysql_password database = your_database_nameNote: Ensure the MySQL user specified has the necessary privileges to perform the actions you intend to execute.
Usage
Run the script with the following command, specifying the path to your configuration file:
python mcp-mysql-server.py --config config.ini
The script exposes the following tools that you can use to interact with your MySQL database:
test_connection: Tests the connection to the database and returns server information.list_tables: Lists all tables in the current database.read_table: Reads and returns all data from a specified table.write_table: Inserts a new row of data into a specified table.get_table_schema: Returns the schema (column definitions) for a specified table.execute_sql: Executes a custom SQL query and returns the results.
Project Structure
mcp-mysql-server.py: Main script containing the MySQL MCP server implementationconfig.ini: Configuration file for MySQL connection parametersrequirements.txt: List of Python dependencieschanges.log: Log of changes made to the project
Docker Support
This project can be run in Docker containers using Docker Compose. The setup includes:
- A MySQL container with sample data
- The MCP MySQL Server container
Running with Docker
- Make sure you have Docker and Docker Compose installed on your system.
- Clone this repository.
- From the repository root, run:
docker-compose up -d
This will:
- Start a MySQL server with sample data (users and posts tables)
- Start the MCP MySQL Server connected to the MySQL database
Configuration for Docker
A special configuration file (config.docker.ini) is used when running in Docker, which points to the MySQL container.
Testing
Unit tests are provided to ensure the functionality works correctly. The tests use mocking to avoid requiring an actual database connection.
Running Tests Locally
# Make a copy of the main script with underscore naming
cp mcp-mysql-server.py mcp_mysql_server.py
# Run the tests
python -m unittest tests.py
Running Tests with Docker
docker-compose -f docker-compose.test.yml up --build
This will build a test container and run the unit tests within it.
Development
For developers who want to extend this tool, you can add new functionalities by creating additional MCP tools. Each tool is a Python function decorated with @mcp.tool() that handles a specific database operation.
Example of adding a new tool:
@mcp.tool()
def my_new_tool(param1: str, param2: int) -> dict:
"""
Documentation for the new tool.
"""
connection = create_mysql_connection()
cursor = connection.cursor()
try:
# Your tool implementation here
return {"result": "success"}
finally:
cursor.close()
connection.close()
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.
E2B
Using MCP to run code via e2b.
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.