Skip to main content

A MSSQL MCP server using pure Python TDS

Project description

mssql-py-mcp

A MSSQL MCP server implementation in Python, designed to work with the pytds library. This project provides a simple and efficient way to interact with Microsoft SQL Server databases, leveraging the pure Python pytds driver for connectivity.

This project uses pure pytds for database connections.

What is pytds?

pytds is a pure Python implementation of the Tabular Data Stream (TDS) protocol, which is used to communicate with Microsoft SQL Server. Unlike other drivers that rely on native libraries (like FreeTDS), pytds is written entirely in Python, making it platform-independent and easy to install.

Key Features of pytds

  • Pure Python: No external dependencies or compilers needed.
  • Cross-Platform: Runs on any platform where Python is supported.
  • Thread-Safe: Safe to use in multi-threaded applications.
  • Supports various authentication methods: Including SQL Server and Windows authentication.
  • Lightweight: Minimal overhead and easy to integrate.

Features

  • MCP Server: Implements the Minecraft JEWEI MCP protocol for database interaction.
  • MSSQL Connectivity: Connects to Microsoft SQL Server using pytds.
  • Database Operations: Supports executing queries, listing tables, and retrieving database information.
  • Easy Configuration: Uses a .env file for simple setup of database credentials.

Installation

  1. Clone the repository:

    git clone https://github.com/your-username/mssql-py-mcp.git
    cd mssql-py-mcp
    
  2. Create a virtual environment (recommended):

    python -m venv venv
    source venv/bin/activate  # On Windows, use `venv\Scripts\activate`
    
  3. Install dependencies:

    pip install -r requirements.txt
    

Configuration

  1. Create a .env file in the root directory of the project. You can copy the example file:

    cp .env.example .env
    
  2. Edit the .env file with your MSSQL database credentials:

    DB_HOST=your_server_address
    DB_USER=your_username
    DB_PASSWORD=your_password
    DB_NAME=your_database_name
    DB_PORT=1433
    

Usage

Run the MCP server with the following command:

python -m mssql_py_mcp.server

The server will start and listen for incoming MCP connections on the default port.

How It Works

The server listens for MCP commands, establishes a connection to the MSSQL database using pytds, executes the requested queries, and returns the results in the MCP format. The core logic is handled in mssql_py_mcp/core.py, which manages the database connection and query execution.

Contributing

Contributions are welcome! Please open an issue or submit a pull request if you have any improvements or bug fixes.

License

This project is licensed under the MIT License. See the LICENSE file for more details.

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_py_mcp-0.1.2.tar.gz (8.8 kB view details)

Uploaded Source

Built Distribution

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

mssql_py_mcp-0.1.2-py3-none-any.whl (9.6 kB view details)

Uploaded Python 3

File details

Details for the file mssql_py_mcp-0.1.2.tar.gz.

File metadata

  • Download URL: mssql_py_mcp-0.1.2.tar.gz
  • Upload date:
  • Size: 8.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.14

File hashes

Hashes for mssql_py_mcp-0.1.2.tar.gz
Algorithm Hash digest
SHA256 99eacf375d743795da1b5a8f7001c87379e1498e5c6b263789dc8e3557eff0b7
MD5 de5f50edaf413193477b97c25dffcb55
BLAKE2b-256 c4a5fdbd7a52fec6b797d2ed7d981890ffb0e2056b22f61eb156266ad88773cb

See more details on using hashes here.

File details

Details for the file mssql_py_mcp-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for mssql_py_mcp-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 ffc6a17101ef1393c493a7360c6c336761e88410c4e4e26dd476d3a5bd457c0a
MD5 60774a8bdd18cac22d0978f998d4269f
BLAKE2b-256 70400e0c9a766e53f9ba5e443619a4287375bccf9a37a26f17d122e53aec8562

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