- 🚀 零依赖:无需 Node.js 或 Python 环境,单一可执行文件
- 🔒 安全可靠:支持只读模式,防止意外写入操作
- 📊 查询优化:可选的 EXPLAIN 检查,优化查询性能
- 🛠️ 完整 CRUD:支持数据库和表的完整生命周期管理
- ⚡ 高性能:基于 Go 语言开发,性能卓越
- 🎯 易于使用:支持命令行参数和 DSN 两种配置方式
⚠️ 注意:本项目正在积极开发中,建议在生产环境使用前进行充分测试。
从 Releases 页面 下载适合您操作系统的最新版本,并将其放入 $PATH 或您可以轻松访问的位置。
如果您已安装 Go 1.21 或更高版本:
go install -v github.com/pengcunfu/go-mcp-mysql@latest{
"mcpServers": {
"mysql": {
"command": "go-mcp-mysql",
"args": [
"--host", "localhost",
"--user", "root",
"--pass", "password",
"--port", "3306",
"--db", "mydb"
]
}
}
}{
"mcpServers": {
"mysql": {
"command": "go-mcp-mysql",
"args": [
"--dsn", "username:password@tcp(localhost:3306)/mydb?parseTime=true&loc=Local"
]
}
}
}💡 提示:更多 DSN 配置选项请参考 MySQL DSN 文档。
如果二进制文件不在 $PATH 中,需要使用完整路径。例如,Windows 用户可以这样配置:
{
"mcpServers": {
"mysql": {
"command": "C:\\Users\\<username>\\Downloads\\go-mcp-mysql.exe",
"args": ["--host", "localhost", "--user", "root", "--pass", "password"]
}
}
}| 标志 | 说明 |
|---|---|
--read-only |
启用只读模式,仅允许 list、read_ 和 desc_ 开头的工具,防止数据修改 |
--with-explain-check |
在执行 CRUD 查询前使用 EXPLAIN 检查查询计划,帮助优化性能 |
📌 注意:修改标志后需要重启 MCP 服务器才能生效。
列出 MySQL 服务器中的所有数据库。
- 参数:无
- 返回:数据库名称列表
列出 MySQL 服务器中的所有表。
- 参数:
name(可选):表名过滤条件,等同于SHOW TABLES LIKE '%name%'
- 返回:匹配的表名称列表
在 MySQL 服务器中创建新表。
- 参数:
query:CREATE TABLE SQL 语句
- 返回:受影响的行数
修改现有表结构(不支持删除表或列)。
- 参数:
query:ALTER TABLE SQL 语句
- 返回:受影响的行数
查看表结构详情。
- 参数:
name:表名
- 返回:表的结构信息
执行只读 SQL 查询(SELECT)。
- 参数:
query:SELECT SQL 语句
- 返回:查询结果集
执行写入 SQL 查询(INSERT)。
- 参数:
query:INSERT SQL 语句
- 返回:受影响的行数和最后插入的 ID
执行更新 SQL 查询(UPDATE)。
- 参数:
query:UPDATE SQL 语句
- 返回:受影响的行数
执行删除 SQL 查询(DELETE)。
- 参数:
query:DELETE SQL 语句
- 返回:受影响的行数
欢迎贡献!如果您有任何想法、建议或发现了 bug,请:
- Fork 本仓库
- 创建您的特性分支 (
git checkout -b feature/AmazingFeature) - 提交您的更改 (
git commit -m 'Add some AmazingFeature') - 推送到分支 (
git push origin feature/AmazingFeature) - 开启一个 Pull Request
本项目采用 Apache License 2.0 许可证。
pengcunfu
- GitHub: @pengcunfu
如果这个项目对您有帮助,请给它一个 ⭐️!