Skip to main content

High-performance MSSQL MCP Server

Project description

MSSQL MCP Server

Model Context Protocol (MCP) Server để tương tác với cơ sở dữ liệu Microsoft SQL Server. Server này cho phép các AI agent tự động quét toàn bộ danh sách database, đọc thông tin schema và thực thi các câu lệnh truy vấn (read-only) một cách an toàn.

Tính năng

🗄️ Quản lý Đa Cơ Sở Dữ Liệu (Multi-Database Auto-Scan)

  • mssql_list_databases: Tự động kết nối đến server và quét danh sách toàn bộ các cơ sở dữ liệu đang có (trạng thái ONLINE).
  • Các công cụ thao tác đều hỗ trợ tham số database_name để AI có thể tự do chỉ định database cần truy vấn mà không cần anh cấu hình từng cái một.

🔍 Thực thi truy vấn (Query Execution)

  • mssql_execute_query: Chạy các câu lệnh SQL trên một database chỉ định.
  • An toàn là trên hết (Safety First): Chỉ cho phép các thao tác chỉ đọc (SELECT, WITH, EXEC, SHOW).
  • Danh sách từ khóa cấm (Keyword Blacklist): Tự động chặn bất kỳ câu truy vấn nào chứa các từ khóa phá hoại như DROP, DELETE, UPDATE, INSERT, ALTER, hoặc TRUNCATE.

📊 Khám phá Schema (Schema Exploration)

  • mssql_list_tables: Liệt kê tất cả các bảng trong một schema cụ thể (mặc định là dbo).
  • mssql_describe_table: Lấy metadata chi tiết cho các cột của một bảng cụ thể (kiểu dữ liệu, cho phép null, độ dài tối đa).

Cài đặt

Yêu cầu hệ thống (Prerequisites)

  • Python 3.12+
  • uv (khuyên dùng) hoặc pip
  • ODBC Driver cho SQL Server (ví dụ: ODBC Driver 17 for SQL Server) đã được cài đặt trên máy host.

Thiết lập (Setup)

# Di chuyển vào thư mục của server
cd servers/mssql

# Cài đặt các thư viện phụ thuộc bằng uv
uv sync

Cấu hình

Server này đọc cấu hình từ các biến môi trường (environment variables). Anh KHÔNG CẦN chỉ định database cụ thể, chỉ cần cấp thông tin máy chủ để server tự quét:

{
  "mcpServers": {
    "mssql-mcp-server": {
      "command": "uv",
      "args": [
        "run",
        "--directory",
        "C:\\Users\\NamHT\\Documents\\Sources\\ArcticFactory.Tools\\servers\\mssql",
        "src/mssql_mcp_server.py"
      ],
      "env": {
        "MSSQL_SERVER": "localhost",
        "MSSQL_USER": "sa",
        "MSSQL_PASSWORD": "your_password",
        "MSSQL_PORT": "1433",
        "MSSQL_DRIVER": "ODBC Driver 17 for SQL Server"
      }
    }
  }
}

Các trường cấu hình (Configuration Fields)

  • MSSQL_SERVER (bắt buộc): Hostname hoặc địa chỉ IP của Server.
  • MSSQL_USER (bắt buộc): Tên đăng nhập (username) SQL Server.
  • MSSQL_PASSWORD (bắt buộc): Mật khẩu đăng nhập SQL Server.
  • MSSQL_PORT (tùy chọn): Cổng kết nối (mặc định là 1433).
  • MSSQL_DRIVER (tùy chọn): Tên của ODBC driver (mặc định là "ODBC Driver 17 for SQL Server").

Chạy Server (Run Server)

Chạy như một MCP Server (Stdio)

uv run src/mssql_mcp_server.py

Cấu hình thành một gói Package để chạy qua UVX (Optional)

Nếu anh muốn đẩy lên mạng và chạy trực tiếp bằng uvx mssql-mcp-server (hoặc kéo từ Github):

  • Trong pyproject.toml đã khai báo [project.scripts].
  • Lệnh sẽ tự động gọi hàm main() trong src/mssql_mcp_server.py.
  • Anh có thể đẩy source code lên Github và chạy bằng: uvx git+https://github.com/username/mssql-mcp-server.git

Xử lý lỗi (Error Handling)

Tất cả các công cụ đều trả về chuỗi định dạng JSON hoặc thông báo lỗi rõ ràng:

  • Lỗi xác thực sẽ trả về lỗi kết nối (connection errors).
  • Các câu lệnh phá hoại sẽ trả về một thông báo lỗi rõ ràng "Error: Detected potentially destructive keywords in query."
  • Phản hồi bình thường sẽ bao gồm số lượng dòng, tiêu đề cột và mảng dữ liệu được định dạng phù hợp để LLM có thể đọc hiểu.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mssql_mcp_vn-0.1.1.tar.gz (6.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mssql_mcp_vn-0.1.1-py3-none-any.whl (6.2 kB view details)

Uploaded Python 3

File details

Details for the file mssql_mcp_vn-0.1.1.tar.gz.

File metadata

  • Download URL: mssql_mcp_vn-0.1.1.tar.gz
  • Upload date:
  • Size: 6.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for mssql_mcp_vn-0.1.1.tar.gz
Algorithm Hash digest
SHA256 2d88c47811c50af04c5e569bdfe3177d6ab5f1a6c150427f5619629505f07e2f
MD5 c26b577909921087555a7c2561246af7
BLAKE2b-256 5bf76ebe5e3bca204ba750ba48219ca9192fb0231ba749c2ca5b075e34c085a2

See more details on using hashes here.

File details

Details for the file mssql_mcp_vn-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: mssql_mcp_vn-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 6.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for mssql_mcp_vn-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c5bcb958f9bea743cd53f6fae48afc1d18b8a9cdcb73a902e34024cfb2c217f9
MD5 b3d802ec86aa959aef2950287c57d395
BLAKE2b-256 cb21d16b96b7e5b807651a488cbd46ca5da7c02ed93483f307698dcda3530a96

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page