SqlDb-MCP-Server

SqlDb-MCP-Server

Enables AI assistants to query SQL Server databases and retrieve schema information securely through the Model Context Protocol.

Category
Visit Server

README

SQL Server MCP Server

A Model Context Protocol (MCP) server implementation that provides secure access to SQL Server databases. This server enables AI assistants and other MCP clients to query and interact with SQL Server databases through a standardized interface.

Overview

This MCP server acts as a bridge between MCP clients (like Claude Desktop or other AI assistants) and your SQL Server database, providing controlled access to execute queries and retrieve schema information. It implements the MCP protocol over stdio communication, making it suitable for integration with various AI tools and applications.

Features

Tools

The server exposes two primary tools for database interaction:

1. execute_query

  • Description: Execute any SQL query on the connected database
  • Input: SQL query string
  • Output: Query results in JSON format
  • Use Cases:
    • Data retrieval (SELECT statements)
    • Data manipulation (INSERT, UPDATE, DELETE)
    • Stored procedure execution
    • Complex joins and aggregations

2. get_schema_info

  • Description: Retrieve comprehensive database schema information
  • Input: None required
  • Output: List of all tables and stored procedures in JSON format
  • Use Cases:
    • Database exploration
    • Understanding table structures
    • Discovering available stored procedures
    • Schema documentation

Prerequisites

  • Node.js 20 or higher
  • npm 7 or higher
  • Access to a SQL Server database (Azure SQL, SQL Server, or SQL Server Express)
  • Docker Desktop (for containerized deployment)
  • Azure CLI (for Azure deployment)

Configuration

Environment Variables

The server requires the following environment variables for database connection. Create a .env file in the project root:

# Copy the example file
cp .env.example .env

Edit .env with your database credentials:

# Database Configuration
DB_USER=your_database_username
DB_PASSWORD=your_database_password
DB_SERVER=your_server.database.windows.net
DB_NAME=your_database_name
DB_ENCRYPT=true                    # Use encryption (recommended for Azure SQL)
DB_TRUST_CERT=false                 # Don't trust self-signed certificates

Security Notes

  • Never commit .env files to version control
  • Use Azure Key Vault or similar services for production deployments
  • Consider using Managed Identity for Azure deployments
  • Implement proper firewall rules for database access

Development

Install dependencies:

npm install

Build the server:

npm run build

For development with auto-rebuild:

npm run watch

Build and Testing

Local Build

  1. Install dependencies and build:
npm install
npm run build
  1. Test the build:
node build/index.js

Docker Build

  1. Build the Docker image:
docker build -t sql-server-mcp:latest .
  1. Test with Docker Compose:
docker-compose up

Deployment

Local Installation (Visual Studio Code)

To use with Visual Studio Code and MCP-enabled extensions:

  1. Install Roo Cline Extension (or another MCP-compatible extension):

    • Open VS Code
    • Go to Extensions (Ctrl+Shift+X)
    • Search for "Roo Cline" or your preferred MCP client extension
    • Click Install
  2. Configure MCP Server in VS Code settings:

    Open VS Code settings (settings.json):

    • Press Ctrl+Shift+P (or Cmd+Shift+P on Mac)
    • Type "Preferences: Open Settings (JSON)"
    • Add the MCP server configuration:
{
  "roo-cline.mcpServers": {
    "sql-server": {
      "command": "node",
      "args": ["C:/path/to/sql-server-mcp/build/index.js"],
      "env": {
        "DB_USER": "your_username",
        "DB_PASSWORD": "your_password",
        "DB_SERVER": "your_server.database.windows.net",
        "DB_NAME": "your_database",
        "DB_ENCRYPT": "true",
        "DB_TRUST_CERT": "false"
      }
    }
  }
}
  1. Alternative: Use workspace-specific configuration:

    Create .vscode/settings.json in your workspace root:

{
  "roo-cline.mcpServers": {
    "sql-server": {
      "command": "node",
      "args": ["${workspaceFolder}/sql-server-mcp/build/index.js"],
      "env": {
        "DB_USER": "${env:DB_USER}",
        "DB_PASSWORD": "${env:DB_PASSWORD}",
        "DB_SERVER": "${env:DB_SERVER}",
        "DB_NAME": "${env:DB_NAME}",
        "DB_ENCRYPT": "true",
        "DB_TRUST_CERT": "false"
      }
    }
  }
}

Note: The exact configuration key (e.g., roo-cline.mcpServers) may vary depending on your MCP client extension. Consult your extension's documentation for the correct configuration format.

Azure Deployment

This project includes comprehensive Azure deployment support with multiple options:

Option 1: Quick Deployment Script

Use the included PowerShell script for automated deployment:

# Login to Azure
az login

# Run deployment script
.\deploy-azure.ps1 `
  -ResourceGroupName "mcp-sql-rg" `
  -Location "eastus" `
  -ContainerName "mcp-sql-server"

Option 2: GitHub Actions CI/CD

  1. Fork this repository

  2. Set up GitHub Secrets:

    • AZURE_CREDENTIALS - Service principal JSON
    • DB_USER - Database username
    • DB_PASSWORD - Database password
    • DB_SERVER - Server URL
    • DB_NAME - Database name
    • DB_ENCRYPT - "true" or "false"
    • DB_TRUST_CERT - "true" or "false"
  3. Push to main branch to trigger deployment

Option 3: Manual Azure Container Instance

# Create resource group
az group create --name mcp-sql-rg --location eastus

# Create container registry
az acr create --resource-group mcp-sql-rg --name mcpsqlregistry --sku Basic

# Build and push image
az acr build --registry mcpsqlregistry --image mcp-sql-server:latest .

# Deploy container instance
az container create \
  --resource-group mcp-sql-rg \
  --name mcp-sql-server \
  --image mcpsqlregistry.azurecr.io/mcp-sql-server:latest \
  --cpu 1 --memory 1 \
  --environment-variables \
    DB_USER=$DB_USER \
    DB_SERVER=$DB_SERVER \
    DB_NAME=$DB_NAME \
    DB_ENCRYPT=true \
    DB_TRUST_CERT=false \
  --secure-environment-variables \
    DB_PASSWORD=$DB_PASSWORD

For detailed deployment instructions, see DEPLOYMENT.md.

Debugging

MCP Inspector

Use the MCP Inspector for interactive debugging:

npm run inspector

This will start the inspector and provide a URL to access debugging tools in your browser.

Container Logs

For containerized deployments:

# Docker
docker logs <container-id>

# Azure Container Instance
az container logs --resource-group mcp-sql-rg --name mcp-sql-server

Troubleshooting

Common Issues

  1. Connection Timeout

    • Check firewall rules on SQL Server
    • Verify connection string format
    • Ensure database server is accessible from deployment environment
  2. Authentication Failed

    • Verify credentials in .env file
    • Check SQL Server authentication mode
    • Ensure user has necessary permissions
  3. Build Errors

    • Ensure Node.js 20+ is installed
    • Delete node_modules and run npm install again
    • Check TypeScript compilation errors with npm run build

Security Best Practices

  1. Credential Management

    • Use environment variables, never hardcode credentials
    • Implement Azure Key Vault for production
    • Use Managed Identity when possible
  2. Network Security

    • Configure firewall rules restrictively
    • Use Private Endpoints for Azure SQL
    • Implement VNet integration for containers
  3. Access Control

    • Use least-privilege database accounts
    • Implement row-level security where needed
    • Audit database access regularly

License

MIT

Support

For issues and questions:

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured