MCP MySQL Server

MCP MySQL Server

A robust MCP server for interacting with MySQL databases through AI agents, providing tools for schema analysis, query execution, and dynamic connection management with read-only security.

Category
Visit Server

README

🚀 MCP MySQL Server

Um servidor MCP (Model Context Protocol) robusto e profissional para interação com bancos MySQL através de agentes de IA. Este projeto demonstra implementação avançada de protocolos MCP com gerenciamento inteligente de conexões e ferramentas especializadas para análise de bancos de dados.

✨ Características Principais

  • 🔐 Gerenciamento Inteligente de Conexões - Configuração dinâmica via tools MCP
  • 🛡️ Segurança Robusta - Apenas operações SELECT permitidas, validação de entrada com Zod
  • 🔄 Múltiplos Transportes - Suporte a stdio e SSE para diferentes cenários de uso
  • 📊 Ferramentas Especializadas - Análise de schema, foreign keys e estrutura de tabelas
  • 🚀 Configuração Automática - Descoberta inteligente de configurações MySQL
  • 💡 Fallback Interativo - Solicita configuração quando necessário

🛠️ Ferramentas Disponíveis

🔧 Configuração de Conexão

  • mysql_configure_connection - Configuração dinâmica de conexão MySQL
  • mysql_auto_configure_connection - Descoberta automática de configuração
  • mysql_get_connection_status - Status atual da conexão
  • mysql_check_connection - Teste de conectividade

📊 Operações no Banco

  • mysql_list_tables - Listagem de todas as tabelas
  • mysql_get_table_info - Estrutura detalhada de tabelas
  • mysql_execute_query - Execução de queries SELECT
  • mysql_analyze_schema - Análise completa do schema
  • mysql_list_foreign_keys - Mapeamento de relacionamentos

🚀 Instalação e Configuração

1. Clone e Instale

git clone https://github.com/efeabio/mcp-mysql-server.git
cd mcp-mysql-server
npm install
npm run build

2. Configure o Cursor

Adicione a seguinte configuração no seu arquivo ~/.cursor/mcp.json:

{
  "mcpServers": {
    "mysql": {
      "command": "/caminho/para/seu/projeto/start-mcp.sh"
    }
  }
}

⚠️ Importante: Substitua /caminho/para/seu/projeto/ pelo caminho real onde você clonou o repositório.

3. Configure o start-mcp.sh

Edite o arquivo start-mcp.sh e altere o caminho para corresponder à sua instalação:

#!/bin/bash
node /caminho/para/seu/projeto/dist/index.js

4. Configuração da Conexão MySQL

O projeto oferece 3 formas de configurar a conexão MySQL:

🔧 Configuração Manual via Tool (Recomendado)

Use a tool mysql_configure_connection para configurar dinamicamente:

await mysql_configure_connection({
  host: "localhost",
  port: 3306,
  user: "root",
  password: "sua_senha",
  database: "seu_banco"
});

📁 Configuração via Arquivo

Crie um arquivo config.json na raiz do projeto:

{
  "mysql": {
    "host": "localhost",
    "port": 3306,
    "user": "root",
    "password": "sua_senha",
    "database": "seu_banco"
  }
}

🔍 Descoberta Automática

Use a tool mysql_auto_configure_connection para tentar descobrir configuração automaticamente.

🎯 Casos de Uso

🔍 Análise de Banco de Dados

  • Auditoria de Schema - Mapeamento completo de estruturas
  • Análise de Relacionamentos - Identificação de foreign keys
  • Documentação Automática - Geração de documentação de banco

🤖 Integração com Agentes de IA

  • Consultas Inteligentes - Execução de queries via linguagem natural
  • Exploração Interativa - Descoberta de dados sem conhecimento prévio
  • Análise Automática - Insights sobre estrutura e relacionamentos

🚀 Desenvolvimento e DevOps

  • Migração de Dados - Análise de estrutura antes de migrações
  • Debugging - Investigação de problemas de banco
  • Monitoramento - Verificação de integridade de dados

🔒 Segurança e Boas Práticas

  • Operações Somente Leitura - Apenas SELECT é permitido
  • Validação de Entrada - Schema validation com Zod
  • Teste de Conexão - Verificação antes de aceitar configurações
  • Configuração via Tools - Interface segura para configuração
  • Isolamento de Conexões - Gerenciamento seguro de múltiplas conexões

🚀 Execução

# Modo stdio (padrão para MCP)
./start-mcp.sh

# Modo SSE para desenvolvimento
node dist/index.js sse

📚 Exemplos de Uso

Configuração Inicial

// Configure conexão dinamicamente
await mysql_configure_connection({
  host: "localhost",
  port: 3306,
  user: "root",
  password: "sua_senha",
  database: "test"
});

// Verifique se funcionou
await mysql_check_connection();

// Explore o banco
await mysql_list_tables();

Análise de Schema

// Análise completa
await mysql_analyze_schema();

// Relacionamentos
await mysql_list_foreign_keys();

// Estrutura específica
await mysql_get_table_info("users");

Consultas Personalizadas

// Execute queries SELECT
await mysql_execute_query("SELECT COUNT(*) as total FROM users");

// Análise de dados
await mysql_execute_query("SELECT table_name, table_rows FROM information_schema.tables");

🏗️ Arquitetura

O projeto utiliza uma arquitetura modular com:

  • MCP SDK - Implementação do protocolo Model Context Protocol
  • MySQL2 - Driver nativo e performático para MySQL
  • TypeScript - Tipagem estática e desenvolvimento robusto
  • Zod - Validação de schemas e entrada de dados
  • Express - Suporte opcional para transporte SSE

🔧 Desenvolvimento

# Build do projeto
npm run build

# Execução em modo desenvolvimento
npm start

# Execução com SSE
npm start sse

📄 Licença

MIT License - veja o arquivo LICENSE para detalhes.

🤝 Contribuição

Contribuições são bem-vindas! Este projeto demonstra implementação profissional de protocolos MCP e serve como referência para desenvolvimento de servidores MCP robustos.


Desenvolvido com ❤️ para demonstrar expertise em protocolos MCP, integração com MySQL e desenvolvimento de ferramentas para agentes de IA.

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