mcp-mysql-server

MCP.Pizza Chef: f4ww4z

The mcp-mysql-server is a Model Context Protocol server designed to facilitate seamless interaction between AI models and MySQL databases. It exposes MySQL database operations through a standardized MCP interface, allowing models to query, update, and manage database content in real time. This server supports secure and efficient database connectivity, making it ideal for AI-enhanced workflows that require dynamic data access and manipulation. Installation is straightforward via Smithery or manual npm commands, with configuration managed through environment variables. It integrates smoothly with various LLM providers, enabling advanced data-driven AI applications.

Use This MCP server To

Query MySQL databases for real-time data retrieval Update and modify MySQL database records via AI models Integrate MySQL data into AI-driven workflows Automate database management tasks using AI Enable AI models to analyze structured MySQL data Support dynamic data fetching for conversational agents

README

@f4ww4z/mcp-mysql-server

smithery badge

A Model Context Protocol server that provides MySQL database operations. This server enables AI models to interact with MySQL databases through a standardized interface.

mcp-mysql-server MCP server

Installation

Installing via Smithery

To install MySQL Server for Claude Desktop automatically via Smithery:

npx -y @smithery/cli install @f4ww4z/mcp-mysql-server --client claude

Manual Installation

npx @f4ww4z/mcp-mysql-server

Configuration

The server requires the following environment variables to be set in your MCP settings configuration file:

recommended use

{
  "mcpServers": {
    "mysql": {
      "command": "npx",
      "args": ["-y", "@f4ww4z/mcp-mysql-server", "mysql://user:password@localhost:port/database"],
    }
  }
}
{
  "mcpServers": {
    "mysql": {
      "command": "npx",
      "args": ["-y", "@f4ww4z/mcp-mysql-server"],
      "env": {
        "MYSQL_HOST": "your_host",
        "MYSQL_USER": "your_user",
        "MYSQL_PASSWORD": "your_password",
        "MYSQL_DATABASE": "your_database"
      }
    }
  }
}

Running evals

The evals package loads an mcp client that then runs the index.ts file, so there is no need to rebuild between tests. You can load environment variables by prefixing the npx command. Full documentation can be found here.

OPENAI_API_KEY=your-key  npx mcp-eval src/evals/evals.ts src/index.ts

Available Tools

1. connect_db

Establish connection to MySQL database using provided credentials.

use_mcp_tool({
  server_name: "mysql",
  tool_name: "connect_db",
  arguments: {
    host: "localhost",
    user: "your_user",
    password: "your_password",
    database: "your_database"
  }
});

2. query

Execute SELECT queries with optional prepared statement parameters.

use_mcp_tool({
  server_name: "mysql",
  tool_name: "query",
  arguments: {
    sql: "SELECT * FROM users WHERE id = ?",
    params: [1]
  }
});

3. execute

Execute INSERT, UPDATE, or DELETE queries with optional prepared statement parameters.

use_mcp_tool({
  server_name: "mysql",
  tool_name: "execute",
  arguments: {
    sql: "INSERT INTO users (name, email) VALUES (?, ?)",
    params: ["John Doe", "john@example.com"]
  }
});

4. list_tables

List all tables in the connected database.

use_mcp_tool({
  server_name: "mysql",
  tool_name: "list_tables",
  arguments: {}
});

5. describe_table

Get the structure of a specific table.

use_mcp_tool({
  server_name: "mysql",
  tool_name: "describe_table",
  arguments: {
    table: "users"
  }
});

Features

  • Secure connection handling with automatic cleanup
  • Prepared statement support for query parameters
  • Comprehensive error handling and validation
  • TypeScript support
  • Automatic connection management

Security

  • Uses prepared statements to prevent SQL injection
  • Supports secure password handling through environment variables
  • Validates queries before execution
  • Automatically closes connections when done

Error Handling

The server provides detailed error messages for common issues:

  • Connection failures
  • Invalid queries
  • Missing parameters
  • Database errors

Contributing

Contributions are welcome! Please feel free to submit a Pull Request to https://github.com/f4ww4z/mcp-mysql-server

License

MIT

mcp-mysql-server FAQ

How do I install the mcp-mysql-server?
You can install it automatically using Smithery with 'npx -y @smithery/cli install @f4ww4z/mcp-mysql-server --client claude' or manually via 'npx @f4ww4z/mcp-mysql-server'.
What configuration is required to run the mcp-mysql-server?
You need to set environment variables in your MCP settings configuration file to specify MySQL connection details such as host, user, password, and database name.
Can the mcp-mysql-server work with LLMs other than Claude?
Yes, it is compatible with multiple LLM providers including OpenAI, Claude, and Gemini, enabling broad AI integration.
Is the mcp-mysql-server secure for production use?
Security depends on proper environment variable management and network configuration; it supports secure connections when configured correctly.
Does the mcp-mysql-server support complex SQL queries?
Yes, it allows AI models to execute a wide range of SQL operations including complex queries, inserts, updates, and deletes.
How does the mcp-mysql-server handle errors or failed queries?
It returns structured error messages to the MCP client, allowing AI models to handle exceptions gracefully.
Can I use the mcp-mysql-server for read-only access?
Yes, you can configure permissions to restrict the server to read-only operations if desired.
What platforms support running the mcp-mysql-server?
It runs on any platform supporting Node.js, including Windows, macOS, and Linux.