MySQL MCP Server
Provides comprehensive MySQL database operations including connection management, schema inspection, SELECT/INSERT/UPDATE/DELETE queries, and custom SQL execution with environment-specific safety controls.
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 MCP Servershow the schema of the users table"
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 comprehensive MySQL Model Context Protocol (MCP) server that provides database operations for Cursor IDE.
Features
✅ Connection Management: Connect to any MySQL database
✅ Schema Operations: List databases, tables, describe table structures
✅ Data Operations: SELECT, INSERT, UPDATE, DELETE operations
✅ Advanced Features: View indexes, foreign keys, execute custom queries
✅ Safety: Built-in query limits and error handling
🔒 Production Security: Automatic PII protection and audit logging (production environment only)
Related MCP server: MySQL MCP Server
Prerequisites
Before setting up this MySQL MCP server, ensure you have:
Node.js (v16 or higher) - Required to run the MCP server
MySQL Database - Either local or remote MySQL server access
Cursor IDE - For MCP integration
📁 Repository Note: This repository follows Node.js best practices by excluding
node_modules/anddist/folders. You'll generate these locally after cloning.
Quick Setup
🚀 First Time Setup (After Cloning)
Important: This repository does not include node_modules/ or dist/ folders to keep it lightweight. You'll need to generate them:
Clone the repository:
git clone https://github.com/binoy154/mysql-mcp.git cd mysql-mcp⚠️ Important Path Considerations:
Note the absolute path where you clone this repository (e.g.,
C:/Projects/mysql-mcporE:/mysql-mcp)You'll need this exact path for Cursor MCP configuration later
The built files will be at
YOUR_PATH/dist/index.js
Install dependencies:
npm installThis will create the
node_modules/folder with all required packages.Build the project:
npm run buildThis will create the
dist/folder with compiled JavaScript files.Set up environment variables (optional):
cp .env.example .env # Edit .env with your MySQL credentialsNote: You can also configure credentials directly in Cursor MCP settings.
Configure Cursor MCP:
🔧 IMPORTANT: Update the file path below with your actual clone location!
A single MCP server instance can switch between local, staging, preproduction and production environments at runtime. The
localenvironment allows full read/write access, whilestaging,preproduction, andproductionare configured as read-only for safety. Supply their credentials through environment variables:{ "mcpServers": { "mysql": { "command": "node", "args": ["YOUR_ABSOLUTE_PATH/mysql-mcp/dist/index.js"], "env": { "MYSQL_LOCAL_HOST": "localhost", "MYSQL_LOCAL_PORT": "3306", "MYSQL_LOCAL_USER": "root", "MYSQL_LOCAL_PASSWORD": "localPassword", "MYSQL_LOCAL_DATABASE": "localDatabase", "MYSQL_STAGING_HOST": "staging.db.example.com", "MYSQL_STAGING_PORT": "3306", "MYSQL_STAGING_USER": "staging_user", "MYSQL_STAGING_PASSWORD": "staging_pw", "MYSQL_STAGING_DATABASE": "staging_db", "MYSQL_PREPRODUCTION_HOST": "preprod-db.example.com", "MYSQL_PREPRODUCTION_PORT": "3306", "MYSQL_PREPRODUCTION_USER": "preprod_user", "MYSQL_PREPRODUCTION_PASSWORD": "preprod_pw", "MYSQL_PREPRODUCTION_DATABASE": "preprod_db" } } } }📝 Path Examples - Replace
YOUR_ABSOLUTE_PATH/mysql-mcpwith:Windows:
"C:/Projects/mysql-mcp/dist/index.js"Windows (E drive):
"E:/mysql-mcp/dist/index.js"Mac/Linux:
"/home/username/mysql-mcp/dist/index.js"
⚠️ Critical: Use forward slashes (
/) even on Windows, and ensure the path points to where you actually cloned the repository.Database Safety: The
productioncredentials should point to a read-only slave or replica to guarantee safety. Additionally,stagingandpreproductionenvironments are enforced as read-only at the code level to prevent accidental data modifications.
Available Tools
Connection Tools
connect_database: Connect with custom credentialslist_databases: Show all available databasesuse_database: Switch to a specific databaseswitch_environment: Switch the active DB environment (local,staging,preproduction,production)
Schema Tools
list_tables: List all tables in current databasedescribe_table: Get detailed table schemaget_table_indexes: View table indexesget_foreign_keys: View foreign key relationships
Data Operations
select_query: Execute SELECT queries with automatic LIMITinsert_data: Insert new recordsupdate_data: Update existing recordsdelete_data: Delete recordsexecute_query: Execute any SQL query (use carefully)
Write operations & permission levels
Tool | Local | Staging | Pre-production | Production |
| ✅ Immediate | ❌ READ-ONLY | ❌ READ-ONLY | ❌ READ-ONLY |
Note: Only the local environment allows write operations. All other environments (staging, preproduction, production) are configured as read-only for data safety and integrity.
Example (local only):
{
"name": "update_data",
"arguments": {
"table": "users",
"data": { "status": "active" },
"where": "id = 42"
}
}Usage Examples
Connect to Database
Use the connect_database tool with:
- host: localhost
- port: 3306
- user: myuser
- password: mypassword
- database: myapp_dbQuery Data
Use select_query with query: "SELECT * FROM users WHERE active = 1"Insert Data
Use insert_data with:
- table: "users"
- data: {"name": "John Doe", "email": "john@example.com"}Security Notes
Store database credentials securely using environment variables
SELECT queries automatically include LIMIT 100 unless specified
The server uses parameterized queries for data operations
Ensure your MySQL user has appropriate permissions
🔒 Production Security Features
Automatic PII Protection (Production Environment Only):
Sensitive Data Masking: Columns containing PII (SIN, birth dates, credit cards, etc.) are automatically masked
Audit Logging: All production database access is logged for compliance
Zero Impact on Development: Local, staging, and preproduction environments work exactly as before
Smart Detection: Uses pattern matching to identify sensitive columns (sin, ssn, birth_date, etc.)
Environment Behavior:
Local/Staging/Preproduction: Full data access (no filtering)
Production: Automatic sensitive data masking + audit logging
Example Output in Production:
{
"id": 1,
"name": "John Doe",
"email": "jo***@example.com",
"sin": "12*8",
"birth_date": "19**-**-**"
}Security Status Messages:
🔓 DEVELOPMENT MODE: No data filtering (full access)
🔒 PRODUCTION MODE: Sensitive data protection active
Deployment to Another Computer
❌ What Won't Work
Simply copying the project folder to another computer will not work without proper setup.
✅ Required Steps for New Installation
Install Prerequisites:
Node.js (v16 or higher)
Access to a MySQL database
Clone or Copy Project Files:
git clone https://github.com/binoy154/mysql-mcp.git cd mysql-mcpNote the absolute path where you cloned/copied the project
You'll need this exact path for Cursor MCP configuration
Install Dependencies:
npm installBuild the Project:
npm run buildUpdate Cursor Configuration:
Update the file path in your Cursor MCP settings to match the new location
Example: Change
"E:/mySqlMcp/dist/index.js"to the correct path on the new computer
Configure Database Credentials:
Update environment variables or Cursor MCP configuration with the correct database connection details for the new environment
📁 What's Included vs. What You Need to Build
✅ Included in this repository:
Source code (
src/folder)Configuration files (
package.json,tsconfig.json,README.md)Documentation files
.gitignore(protects against accidentally committing large folders)
🔨 What you need to build after cloning:
node_modules/folder → Runnpm installdist/folder → Runnpm run build
⚙️ What you need to customize:
Database credentials (host, port, username, password)
File paths in Cursor MCP configuration
Environment-specific settings
💡 Why this approach?
Keeps repository lightweight (MB instead of GB)
Avoids platform-specific dependency issues
Follows Node.js best practices
Troubleshooting
Setup Issues
"Cannot find module" errors: Run
npm installto install dependencies"Cannot find dist/index.js": Run
npm run buildto compile TypeScriptMissing
node_modules/folder: This is normal! Runnpm installto create itMissing
dist/folder: This is normal! Runnpm run buildto create it
Connection Issues
Verify MySQL server is running
Check host, port, username, and password
Ensure user has necessary database permissions
Permission Errors
Grant appropriate MySQL privileges:
GRANT SELECT, INSERT, UPDATE, DELETE ON your_database.* TO 'your_user'@'localhost';
FLUSH PRIVILEGES;Deployment Issues
Ensure Node.js is installed on the target computer
Verify the file path in Cursor MCP configuration is correct
Check that
npm installandnpm run buildcompleted successfullyConfirm database connectivity from the new computer
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/binoy154/mysql-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server