MySQL MCP Server

MySQL MCP Server

Enables Cursor IDE to interact with MySQL databases through schema and data operations, including read and write capabilities with environment-specific safety controls.

Category
Visit Server

README

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)

Prerequisites

Before setting up this MySQL MCP server, ensure you have:

  1. Node.js (v16 or higher) - Required to run the MCP server
  2. MySQL Database - Either local or remote MySQL server access
  3. Cursor IDE - For MCP integration

📁 Repository Note: This repository follows Node.js best practices by excluding node_modules/ and dist/ 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:

  1. 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-mcp or E:/mysql-mcp)
    • You'll need this exact path for Cursor MCP configuration later
    • The built files will be at YOUR_PATH/dist/index.js
  2. Install dependencies:

    npm install
    

    This will create the node_modules/ folder with all required packages.

  3. Build the project:

    npm run build
    

    This will create the dist/ folder with compiled JavaScript files.

  4. Set up environment variables (optional):

    cp .env.example .env
    # Edit .env with your MySQL credentials
    

    Note: You can also configure credentials directly in Cursor MCP settings.

  5. 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 local environment allows full read/write access, while staging, preproduction, and production are 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-mcp with:

    • 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 production credentials should point to a read-only slave or replica to guarantee safety. Additionally, staging and preproduction environments are enforced as read-only at the code level to prevent accidental data modifications.

Available Tools

Connection Tools

  • connect_database: Connect with custom credentials
  • list_databases: Show all available databases
  • use_database: Switch to a specific database
  • switch_environment: Switch the active DB environment (local, staging, preproduction, production)

Schema Tools

  • list_tables: List all tables in current database
  • describe_table: Get detailed table schema
  • get_table_indexes: View table indexes
  • get_foreign_keys: View foreign key relationships

Data Operations

  • select_query: Execute SELECT queries with automatic LIMIT
  • insert_data: Insert new records
  • update_data: Update existing records
  • delete_data: Delete records
  • execute_query: Execute any SQL query (use carefully)

Write operations & permission levels

Tool Local Staging Pre-production Production
insert_data, update_data, delete_data, execute_query ✅ 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_db

Query 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

  1. Store database credentials securely using environment variables
  2. SELECT queries automatically include LIMIT 100 unless specified
  3. The server uses parameterized queries for data operations
  4. 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

  1. Install Prerequisites:

    • Node.js (v16 or higher)
    • Access to a MySQL database
  2. Clone or Copy Project Files:

    git clone https://github.com/binoy154/mysql-mcp.git
    cd mysql-mcp
    
    • Note the absolute path where you cloned/copied the project
    • You'll need this exact path for Cursor MCP configuration
  3. Install Dependencies:

    npm install
    
  4. Build the Project:

    npm run build
    
  5. Update 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
  6. 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 → Run npm install
  • dist/ folder → Run npm 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 install to install dependencies
  • "Cannot find dist/index.js": Run npm run build to compile TypeScript
  • Missing node_modules/ folder: This is normal! Run npm install to create it
  • Missing dist/ folder: This is normal! Run npm run build to 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 install and npm run build completed successfully
  • Confirm database connectivity from the new computer

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured