mysql-mcp
Provides MySQL database query capabilities, including executing SQL queries, listing databases and tables, and describing table structures.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mysql-mcplist all tables in the database"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MySQL MCP Server
A Model Context Protocol (MCP) server that provides MySQL database query capabilities. This server allows AI assistants to interact with MySQL databases through a standardized interface.
Features
Execute SQL queries with prepared statement support
List databases and tables
Describe table structures
Secure connection management with environment variables
Error handling and connection recovery
Support for all MySQL data types
Related MCP server: MySQL MCP Server
Installation
Clone or download this project
Install dependencies:
npm installCopy the environment configuration:
cp .env.example .envConfigure your MySQL connection in
.env:MYSQL_HOST=localhost MYSQL_PORT=3306 MYSQL_USER=your_username MYSQL_PASSWORD=your_password MYSQL_DATABASE=your_database
Usage
Running the Server
# Start the server
npm start
# Development mode with auto-restart
npm run devAvailable Tools
1. mysql_query
Execute SQL queries with optional prepared statement parameters.
Parameters:
query(required): The SQL query to executeparameters(optional): Array of parameters for prepared statements
Examples:
-- Simple SELECT
SELECT * FROM users LIMIT 10
-- Prepared statement with parameters
SELECT * FROM users WHERE age > ? AND city = ?
-- Parameters: ["25", "New York"]
-- INSERT with prepared statement
INSERT INTO users (name, email, age) VALUES (?, ?, ?)
-- Parameters: ["John Doe", "john@example.com", "30"]2. mysql_describe_table
Get the structure of a specific table.
Parameters:
table_name(required): Name of the table to describe
3. mysql_list_tables
List all tables in the current database.
Parameters: None
4. mysql_list_databases
List all databases accessible to the current user.
Parameters: None
Configuration with MCP Clients
Claude Desktop
Add this server to your Claude Desktop configuration file:
Windows: %APPDATA%\Claude\claude_desktop_config.json
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
{
"mcpServers": {
"mysql": {
"command": "node",
"args": ["path/to/mysql-mcp/server.js"],
"env": {
"MYSQL_HOST": "localhost",
"MYSQL_PORT": "3306",
"MYSQL_USER": "your_username",
"MYSQL_PASSWORD": "your_password",
"MYSQL_DATABASE": "your_database"
}
}
}
}Other MCP Clients
This server follows the standard MCP protocol and should work with any compatible client. Refer to your client's documentation for configuration details.
Security Considerations
Environment Variables: Never commit your
.envfile with actual credentialsDatabase Permissions: Use a database user with minimal required permissions
Network Security: Ensure your MySQL server is properly secured
Query Validation: The server executes queries as provided - ensure your AI assistant is configured appropriately
Database Permissions
For security, create a dedicated MySQL user for the MCP server:
-- Create a dedicated user
CREATE USER 'mcp_user'@'localhost' IDENTIFIED BY 'secure_password';
-- Grant necessary permissions (adjust as needed)
GRANT SELECT, INSERT, UPDATE, DELETE ON your_database.* TO 'mcp_user'@'localhost';
-- For read-only access, use only:
-- GRANT SELECT ON your_database.* TO 'mcp_user'@'localhost';
-- Apply changes
FLUSH PRIVILEGES;Troubleshooting
Connection Issues
Check MySQL server status:
# Linux/macOS sudo systemctl status mysql # Windows (if using MySQL service) net start mysqlVerify connection parameters in
.envCheck MySQL user permissions:
SHOW GRANTS FOR 'your_username'@'localhost';
Common Errors
"Access denied": Check username/password in
.env"Unknown database": Verify database name exists
"Connection refused": Check if MySQL server is running and host/port are correct
Development
Project Structure
mysql-mcp/
├── server.js # Main MCP server implementation
├── package.json # Node.js dependencies and scripts
├── .env.example # Environment configuration template
├── .env # Your local configuration (not in git)
├── README.md # This file
└── .gitignore # Git ignore rulesAdding New Tools
To add new database tools, extend the setupToolHandlers() method in server.js:
Add the tool definition in
ListToolsRequestSchemahandlerAdd the case in
CallToolRequestSchemahandlerImplement the handler method
License
ISC License
Contributing
Fork the repository
Create a feature branch
Make your changes
Test thoroughly
Submit a pull request
Support
For issues and questions:
Check the troubleshooting section
Review MySQL and MCP documentation
Create an issue in the project repository
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/douglasaxel/mysql-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server