SQL Server Agent - Modal Context Protocol

SQL Server Agent - Modal Context Protocol

一个模型上下文协议(MCP)的实现,使得大型语言模型(LLM)和 SQL Server 之间能够进行通信。它允许用户使用自然语言查询 SQL 数据库,并获得结构化的 SQL 响应。

aman-panjwani

研究与数据
访问服务器

README

SQL Server Agent - 模态上下文协议

这里是 SQL Server Agent,它允许您使用自然语言与 SQL Server 数据库进行交互,利用模态上下文协议作为 LLM 和数据源之间的层。

主要特性:

  • 与您的数据库对话:使用简单的英语与 SQL Server 聊天。
  • 无代码数据库操作:完全通过自然对话管理您的数据库任务。
  • 一键式过程执行:通过自然命令轻松运行存储过程。
  • MCP 增强的准确性:通过模态上下文协议 (MCP) 实现精确的数据库交互,智能地将您的命令连接到数据。
  • 上下文感知对话:享受由模态上下文协议驱动的无缝交互。

什么是 MCP?

MCP(模态上下文协议)是一种方法论,它规定了我们应该如何将上下文绑定到 LLM。 MCP 提供了一种标准化的方式,将 AI 模型连接到不同的数据源和工具。

为什么选择 MCP?

MCP 帮助我们以简化的方式构建复杂的 LLM 之上的 Agent 工作流程,其中语言模型需要与数据源和工具进行频繁集成。

MCP 架构:

MCP 架构遵循客户端-服务器模型,允许单个客户端与多个服务器无缝交互。

MCP 架构

MCP-Client:您的 AI 客户端 (LLM) 访问数据。

MCP-Protocol:将您的客户端直接连接到服务器。

MCP-Server:帮助您的客户端通过 MCP 访问数据源。

本地数据库、云数据库、外部 API:通过本地存储、云或在线 API 提供数据的来源。

现在,让我们深入研究实现

在了解 MCP 及其架构之后,现在是时候将所有内容与 SQL Server Agent 结合在一起了。

什么是 SQL Server Agent?

SQL Server Agent 是一个对话式 AI 查询 CLI,使您能够使用自然语言与 SQL Server 数据库进行交互。 由模态上下文协议提供支持,它充当您的语言模型和数据库之间的智能层,从而可以:

  • 无需编写 SQL 即可查询数据库
  • 使用对话命令执行存储过程
  • 执行复杂操作,同时保持跨多个步骤的上下文

无论您是开发人员、分析师还是非技术用户,此代理都可以通过直观的、类似人类的交互来访问您的数据。

现在,让我们逐步了解如何启动并运行它 👇

前提条件

在开始之前,请确保您具备以下条件:

  • 您的机器上安装了 Python 3.12+
  • 有效的 OpenAI API 密钥

开始使用

按照以下步骤启动并运行项目:

1. 克隆存储库

git clone https://github.com/Amanp17/mcp-sql-server-natural-lang.git
cd mcp-sql-server-natural-lang

2. 安装依赖项

pip install -r requirements.txt

3. 设置环境变量

在项目根目录中创建一个 .env 文件,并添加以下内容:

OPENAI_API_KEY=your_openai_api_key
MSSQL_SERVER=localhost
MSSQL_DATABASE=your_database_name
MSSQL_USERNAME=your_username
MSSQL_PASSWORD=your_password
MSSQL_DRIVER={ODBC Driver 17 for SQL Server}

运行 SQL Server Agent

设置好您的环境和依赖项后,您就可以与 SQL Server Agent 交互了。

运行客户端脚本

执行以下命令以启动代理:

python mcp-ssms-client.py

脚本启动后,它将提示您如下所示:

Enter your Query:

现在,您可以用简单的英语输入您的请求。 例如:

Create a Employee table with 10 dummy data in it with their departments and salaries.

代理将使用模态上下文协议处理您的输入,并从您的 SQL Server 数据库返回相关数据。

🧠 提示:您可以提出后续问题或提出诸如“显示员工及其部门?”或“有多少员工的薪水低于 40K 美元?”之类的请求——上下文被保留!

结论

模态上下文协议 (MCP) 提供支持的 SQL Server Agent 将对话式 AI 的强大功能带到您的数据库操作中。 通过弥合自然语言和 SQL 之间的差距,它允许用户毫不费力地与他们的数据进行交互,从而使数据库访问更加直观、高效,并且对每个人(即使是没有技术专业知识的人)都更容易访问。

无论您是查询数据、执行过程还是构建复杂的工作流程,此代理都可以作为您与 SQL Server 的智能接口。

欢迎贡献、提出问题或提出改进建议——我们正在共同构建 AI 驱动的数据交互的未来! 🚀

推荐服务器

Crypto Price & Market Analysis MCP Server

Crypto Price & Market Analysis MCP Server

一个模型上下文协议 (MCP) 服务器,它使用 CoinCap API 提供全面的加密货币分析。该服务器通过一个易于使用的界面提供实时价格数据、市场分析和历史趋势。 (Alternative, slightly more formal and technical translation): 一个模型上下文协议 (MCP) 服务器,利用 CoinCap API 提供全面的加密货币分析服务。该服务器通过用户友好的界面,提供实时价格数据、市场分析以及历史趋势数据。

精选
TypeScript
MCP PubMed Search

MCP PubMed Search

用于搜索 PubMed 的服务器(PubMed 是一个免费的在线数据库,用户可以在其中搜索生物医学和生命科学文献)。 我是在 MCP 发布当天创建的,但当时正在度假。 我看到有人在您的数据库中发布了类似的服务器,但还是决定发布我的服务器。

精选
Python
mixpanel

mixpanel

连接到您的 Mixpanel 数据。 从 Mixpanel 分析查询事件、留存和漏斗数据。

精选
TypeScript
Sequential Thinking MCP Server

Sequential Thinking MCP Server

这个服务器通过将复杂问题分解为顺序步骤来促进结构化的问题解决,支持修订,并通过完整的 MCP 集成来实现多条解决方案路径。

精选
Python
Nefino MCP Server

Nefino MCP Server

为大型语言模型提供访问德国可再生能源项目新闻和信息的能力,允许按地点、主题(太阳能、风能、氢能)和日期范围进行筛选。

官方
Python
Vectorize

Vectorize

将 MCP 服务器向量化以实现高级检索、私有深度研究、Anything-to-Markdown 文件提取和文本分块。

官方
JavaScript
Mathematica Documentation MCP server

Mathematica Documentation MCP server

一个服务器,通过 FastMCP 提供对 Mathematica 文档的访问,使用户能够从 Wolfram Mathematica 检索函数文档和列出软件包符号。

本地
Python
kb-mcp-server

kb-mcp-server

一个 MCP 服务器,旨在实现便携性、本地化、简易性和便利性,以支持对 txtai “all in one” 嵌入数据库进行基于语义/图的检索。任何 tar.gz 格式的 txtai 嵌入数据库都可以被加载。

本地
Python
Research MCP Server

Research MCP Server

这个服务器用作 MCP 服务器,与 Notion 交互以检索和创建调查数据,并与 Claude Desktop Client 集成以进行和审查调查。

本地
Python
Cryo MCP Server

Cryo MCP Server

一个API服务器,实现了模型补全协议(MCP),用于Cryo区块链数据提取,允许用户通过任何兼容MCP的客户端查询以太坊区块链数据。

本地
Python