MySQL MCP Server
Provides tools for querying MySQL databases, including read-only operations by default, with optional write operations (INSERT, UPDATE, DELETE) and DDL operations. Supports schema inspection, multi-database mode, SSH tunneling, and security features like read-only transaction enforcement and cross-database access control.
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 me the users table schema"
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 服务 - Claude Code
🚀 这是一个 MySQL MCP 服务,适用于最新版本 Claude Code
本项目是基于 @benborla29 的 mcp-server-mysql 项目,针对 Claude Code 做的增强优化
基于 NodeJS 的 MySQL MCP 服务
🌟该项目如对您有帮助,欢迎点赞🌟
此分支的主要特点:
✅ 最新 Claude Code 兼容 - 完全兼容最新版本的 Claude Code ,提供稳定的数据库访问体验
✅ 增强数据库访问验证 - 当设置
MYSQL_DB时,严格验证 SQL 查询的数据库访问,确保查询只作用于指定数据库,避免意外的跨库操作✅ SSH 隧道支持 - 内置支持远程数据库的 SSH 隧道
✅ 自动启动 / 停止钩子 - 与 Claude 启动 / 停止配合的自动隧道管理
✅ DDL 操作 - 添加了
MYSQL_DISABLE_READ_ONLY_TRANSACTIONS以支持CREATE TABLE✅ 多项目设置 - 轻松配置多个具有不同数据库的项目
Claude Code 用户快速入门:
阅读设置指南:详见 PROJECT_SETUP_GUIDE.md 获取详细说明
配置 SSH 隧道:为远程数据库设置自动 SSH 隧道
与 Claude 配合使用:集成的 MCP 服务与 Claude Code 无缝协作
一个模型上下文协议服务器,通过 SSH 隧道提供对 MySQL 数据库的访问。该服务器使 Claude 和其他大型语言模型能够安全地检查数据库模式和执行 SQL 查询。
目录
要求
Node.js v20 或更高版本
MySQL 5.7 或更高版本(推荐 MySQL 8.0+)
具有所需操作适当权限的 MySQL 用户
对于写入操作:具有 INSERT、UPDATE 和 DELETE 权限的 MySQL 用户
安装
Claude Code
本项目专为 Claude Code 优化,提供完整的 MySQL 数据库访问功能。请按照下方的安装指南进行配置。
从本地仓库运行
如果直接从源代码克隆并运行此 MCP 服务,请按照以下步骤操作:
克隆仓库
git clone https://github.com/chenlinyang/mcp-server-mysql.git cd mcp-server-mysql安装依赖项
npm install # 或 pnpm install构建项目
npm run build # 或 pnpm run build配置 Claude Code
将以下内容添加到您的 Claude Code 配置文件(Linux和MacOS一般是
~/.claude.json,windows一般是%USERPROFILE%/.claude.json):{ "mcpServers": { "mcp_server_mysql": { "command": "/path/to/node", "args": [ "/full/path/to/mcp-server-mysql/dist/index.js" ], "env": { "MYSQL_HOST": "127.0.0.1", "MYSQL_PORT": "3306", "MYSQL_USER": "root", "MYSQL_PASS": "your_password", "MYSQL_DB": "your_database", "MULTI_DB_WRITE_MODE": "false", "ALLOW_INSERT_OPERATION": "false", "ALLOW_UPDATE_OPERATION": "false", "ALLOW_DELETE_OPERATION": "false" } } } }替换:
/path/to/node为 Node.js 二进制文件的完整路径(使用which node找到它)/full/path/to/mcp-server-mysql为您克隆仓库的完整路径设置 MySQL 凭据以匹配您的环境
测试服务
# 直接运行服务进行测试 node dist/index.js如果它成功连接到 MySQL,您就可以将其与 Claude Code 一起使用了。
以全局模式安装运行
全局安装
# 全局安装 npm install -g @chenlinyang/mcp-server-mysql # 或者使用 pnpm pnpm add -g @chenlinyang/mcp-server-mysql配置 Claude Code
方法一:使用命令行
claude mcp add -s user mysql -- npx -y "@chenlinyang/mcp-server-mysql"方法二:手动配置
将以下内容添加到您的 Claude Code 配置文件(
.claude.json):{ "mcpServers": { "mcp_server_mysql": { "command": "npx", "args": [ "@chenlinyang/mcp-server-mysql" ], "env": { } } } }
在首选目录中创建 .env 文件
# 创建 .env 文件 touch .env将此仓库中的 .env 文件内容复制粘贴到您刚创建的 .env 文件中。
首选目录
.env文件主要环境变量:# 基本连接设置 MYSQL_HOST=127.0.0.1 MYSQL_PORT=3306 MYSQL_USER=root MYSQL_PASS=root MYSQL_DB=test_db # 写入操作标识 ALLOW_INSERT_OPERATION=false ALLOW_UPDATE_OPERATION=false ALLOW_DELETE_OPERATION=false ALLOW_DDL_OPERATION=true # 在多数据库模式下启用写入操作 MULTI_DB_WRITE_MODE=false测试验证
添加服务后,测试验证其配置是否正确:
# 列出所有配置的MCP服务 claude mcp list # 获取 MySQL 服务器的详细信息 claude mcp get mcp_server_mysql # 在 Claude Code 中检查服务状态 /mcp
执行简单的统计分析
结合agent进行架构分析
数据库架构师 提示词参考
.claude\agents\database-architect.md
组件
工具
mysql_query
对连接的数据库执行 SQL 查询
输入:
sql(字符串):要执行的 SQL 查询默认情况下,仅限于只读操作
可选的写入操作(当通过配置启用时):
INSERT:向表中添加新数据(需要
ALLOW_INSERT_OPERATION=true)UPDATE:修改现有数据(需要
ALLOW_UPDATE_OPERATION=true)DELETE:删除数据(需要
ALLOW_DELETE_OPERATION=true)
所有操作都在事务中执行,并具有适当的提交 / 回滚处理
支持预准备语句以安全处理参数
可配置的查询超时和结果分页
内置查询执行统计信息
资源
服务提供全面的数据库信息:
表模式
每个表的 JSON 模式信息
列名和数据类型
索引信息和约束
外键关系
表统计信息和指标
从数据库元数据自动发现
安全功能
通过预准备语句防止 SQL 注入
增强数据库访问控制 - 当设置
MYSQL_DB时,自动验证并阻止跨数据库查询,确保数据安全查询白名单 / 黑名单功能
查询执行速率限制
查询复杂度分析
可配置的连接加密
只读事务强制
性能优化
优化的连接池
查询结果缓存
大结果集流
查询执行计划分析
可配置的查询超时
监控和调试
全面的查询日志记录
性能指标收集
错误跟踪和报告
健康检查端点
查询执行统计信息
配置
您可以更新任何 MySQL 连接详细信息以及写入操作设置:
基本连接设置:
MySQL 主机、端口、用户、密码、数据库
SSL/TLS 配置(如果您的数据库需要安全连接)
写入操作权限:
允许 INSERT 操作:如果您希望允许添加新数据,请设置为 true
允许 UPDATE 操作:如果您希望允许更新现有数据,请设置为 true
允许 DELETE 操作:如果您希望允许删除数据,请设置为 true
出于安全原因,所有写入操作默认都是禁用的。只有在您特别需要 Claude 修改数据库数据时才启用这些设置。
高级配置选项
要更好地控制 MCP 服务的行为,您可以使用这些高级配置选项:
{
"mcpServers": {
"mcp_server_mysql": {
"command": "/path/to/npx/binary/npx",
"args": [
"-y",
"@chenlinyang/mcp-server-mysql"
],
"env": {
// 基本连接设置
"MYSQL_HOST": "127.0.0.1",
"MYSQL_PORT": "3306",
"MYSQL_USER": "root",
"MYSQL_PASS": "",
"MYSQL_DB": "db_name",
"PATH": "/path/to/node/bin:/usr/bin:/bin",
// 性能设置
"MYSQL_POOL_SIZE": "10",
"MYSQL_QUERY_TIMEOUT": "30000",
"MYSQL_CACHE_TTL": "60000",
// 安全设置
"MYSQL_RATE_LIMIT": "100",
"MYSQL_MAX_QUERY_COMPLEXITY": "1000",
"MYSQL_SSL": "true",
// 监控设置
"MYSQL_ENABLE_LOGGING": "true",
"MYSQL_LOG_LEVEL": "info",
"MYSQL_METRICS_ENABLED": "true",
// 写入操作标志
"ALLOW_INSERT_OPERATION": "false",
"ALLOW_UPDATE_OPERATION": "false",
"ALLOW_DELETE_OPERATION": "false"
}
}
}
}环境变量
基本连接
MYSQL_SOCKET_PATH:本地连接的 Unix 套接字路径(例如,"/tmp/mysql.sock")MYSQL_HOST:MySQL 服务器主机(默认:"127.0.0.1")- 如果设置了 MYSQL_SOCKET_PATH,则忽略MYSQL_PORT:MySQL 服务器端口(默认:"3306")- 如果设置了 MYSQL_SOCKET_PATH,则忽略MYSQL_USER:MySQL 用户名(默认:"root")MYSQL_PASS:MySQL 密码MYSQL_DB:目标数据库名称(多数据库模式留空)- 增强功能:设置后将严格限制查询只访问此数据库,防止意外的跨库操作
性能配置
MYSQL_POOL_SIZE:连接池大小(默认:"10")MYSQL_QUERY_TIMEOUT:查询超时(毫秒)(默认:"30000")MYSQL_CACHE_TTL:缓存生存时间(毫秒)(默认:"60000")
安全配置
MYSQL_RATE_LIMIT:每分钟最大查询数(默认:"100")MYSQL_MAX_QUERY_COMPLEXITY:最大查询复杂度分数(默认:"1000")MYSQL_SSL:启用 SSL/TLS 加密(默认:"false")ALLOW_INSERT_OPERATION:启用 INSERT 操作(默认:"false")ALLOW_UPDATE_OPERATION:启用 UPDATE 操作(默认:"false")ALLOW_DELETE_OPERATION:启用 DELETE 操作(默认:"false")ALLOW_DDL_OPERATION:启用 DDL 操作(默认:"false")MYSQL_DISABLE_READ_ONLY_TRANSACTIONS:[新增] 禁用只读事务强制(默认:"false")⚠️ 安全警告: 仅在您需要完全写入权限且信任 LLM 处理您的数据库时启用此功能SCHEMA_INSERT_PERMISSIONS:模式特定的 INSERT 权限SCHEMA_UPDATE_PERMISSIONS:模式特定的 UPDATE 权限SCHEMA_DELETE_PERMISSIONS:模式特定的 DELETE 权限SCHEMA_DDL_PERMISSIONS:模式特定的 DDL 权限MULTI_DB_WRITE_MODE:在多数据库模式下启用写入操作(默认:"false")
监控配置
MYSQL_ENABLE_LOGGING:启用查询日志记录(默认:"false")MYSQL_LOG_LEVEL:日志级别(默认:"info")MYSQL_METRICS_ENABLED:启用性能指标(默认:"false")
多数据库模式
当未设置特定数据库时,MCP-Server-MySQL 支持连接到多个数据库。这允许 LLM 查询 MySQL 用户有权访问的任何数据库。有关完整详情,请参见 README-MULTI-DB.md。
启用多数据库模式
要启用多数据库模式,只需将 MYSQL_DB 环境变量留空。在多数据库模式下,查询需要模式限定:
-- 使用完全限定的表名
SELECT * FROM database_name.table_name;
-- 或者使用 USE 语句在数据库之间切换
USE database_name;
SELECT * FROM table_name;模式特定权限
为了对数据库操作进行细粒度控制,MCP-Server-MySQL 现在支持模式特定权限。这允许不同的数据库具有不同的访问级别(只读、读写等)。
配置示例
SCHEMA_INSERT_PERMISSIONS=development:true,test:true,production:false
SCHEMA_UPDATE_PERMISSIONS=development:true,test:true,production:false
SCHEMA_DELETE_PERMISSIONS=development:false,test:true,production:false
SCHEMA_DDL_PERMISSIONS=development:false,test:true,production:false有关完整详情和安全建议,请参见 README-MULTI-DB.md。
测试
数据库设置
运行测试前,您需要设置测试数据库并填充测试数据:
创建测试数据库和用户
-- 以 root 身份连接并创建测试数据库 CREATE DATABASE IF NOT EXISTS mcp_test; -- 创建具有适当权限的测试用户 CREATE USER IF NOT EXISTS 'mcp_test'@'localhost' IDENTIFIED BY 'mcp_test_password'; GRANT ALL PRIVILEGES ON mcp_test.* TO 'mcp_test'@'localhost'; FLUSH PRIVILEGES;运行数据库设置脚本
# 运行数据库设置脚本 npm run setup:test:db这将创建必要的表和种子数据。该脚本位于
scripts/setup-test-db.ts配置测试环境
在项目根目录中创建
.env.test文件(如果不存在):MYSQL_HOST=127.0.0.1 MYSQL_PORT=3306 MYSQL_USER=mcp_test MYSQL_PASS=mcp_test_password MYSQL_DB=mcp_test更新 package.json 脚本
将这些脚本添加到您的 package.json:
{ "scripts": { "setup:test:db": "ts-node scripts/setup-test-db.ts", "pretest": "pnpm run setup:test:db", "test": "vitest run", "test:watch": "vitest", "test:coverage": "vitest run --coverage" } }
运行测试
该项目包括一个全面的测试套件,以确保功能和可靠性:
# 首次设置
pnpm run setup:test:db
# 运行所有测试
pnpm test运行评估
评估包加载一个 mcp 客户端,然后运行 index.ts 文件,因此测试之间无需重建。您可以通过前缀 npx 命令来加载环境变量。完整文档可在 MCP Evals 找到。
OPENAI_API_KEY=your-key npx mcp-eval evals.ts index.ts故障排除
常见问题
连接问题
验证 MySQL 服务器是否正在运行且可访问
检查凭据和权限
如果启用,确保 SSL/TLS 配置正确
尝试使用 MySQL 客户端连接以确认访问权限
性能问题
调整连接池大小
配置查询超时值
必要时启用查询缓存
检查查询复杂度设置
监控服务器资源使用情况
安全限制
查看速率限制配置
检查查询白名单 / 黑名单设置
验证 SSL/TLS 设置
确保用户具有适当的 MySQL 权限
数据库访问验证问题
如果设置了
MYSQL_DB但仍然收到跨数据库访问错误,请检查 SQL 查询中是否明确指定了数据库名称确保所有表引用都指向正确的数据库,使用
database.table格式或先执行USE database语句在单数据库模式下,系统会自动阻止对其他数据库的访问以提高安全性
路径解析
如果遇到错误 "Could not connect to MCP server mcp-server-mysql",显式设置所有必需二进制文件的路径:
{ "env": { "PATH": "/path/to/node/bin:/usr/bin:/bin" } }我在哪里可以找到我的
node二进制路径?运行以下命令获取:
对于 PATH:
echo "$(which node)/../"对于 NODE_PATH:
echo "$(which node)/../../lib/node_modules"
许可证
本项目基于 MIT 许可证开源。详见 LICENSE 文件。
贡献
欢迎提交 Issue 和 Pull Request 来改进这个项目。
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/chenlinyang/mcp-server-mysql'
If you have feedback or need assistance with the MCP directory API, please join our Discord server