SqlDb-MCP-Server
Enables AI assistants to query SQL Server databases and retrieve schema information securely through the Model Context Protocol.
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
.envfiles 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
- Install dependencies and build:
npm install
npm run build
- Test the build:
node build/index.js
Docker Build
- Build the Docker image:
docker build -t sql-server-mcp:latest .
- Test with Docker Compose:
docker-compose up
Deployment
Local Installation (Visual Studio Code)
To use with Visual Studio Code and MCP-enabled extensions:
-
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
-
Configure MCP Server in VS Code settings:
Open VS Code settings (
settings.json):- Press
Ctrl+Shift+P(orCmd+Shift+Pon Mac) - Type "Preferences: Open Settings (JSON)"
- Add the MCP server configuration:
- Press
{
"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"
}
}
}
}
-
Alternative: Use workspace-specific configuration:
Create
.vscode/settings.jsonin 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
-
Fork this repository
-
Set up GitHub Secrets:
AZURE_CREDENTIALS- Service principal JSONDB_USER- Database usernameDB_PASSWORD- Database passwordDB_SERVER- Server URLDB_NAME- Database nameDB_ENCRYPT- "true" or "false"DB_TRUST_CERT- "true" or "false"
-
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
-
Connection Timeout
- Check firewall rules on SQL Server
- Verify connection string format
- Ensure database server is accessible from deployment environment
-
Authentication Failed
- Verify credentials in
.envfile - Check SQL Server authentication mode
- Ensure user has necessary permissions
- Verify credentials in
-
Build Errors
- Ensure Node.js 20+ is installed
- Delete
node_modulesand runnpm installagain - Check TypeScript compilation errors with
npm run build
Security Best Practices
-
Credential Management
- Use environment variables, never hardcode credentials
- Implement Azure Key Vault for production
- Use Managed Identity when possible
-
Network Security
- Configure firewall rules restrictively
- Use Private Endpoints for Azure SQL
- Implement VNet integration for containers
-
Access Control
- Use least-privilege database accounts
- Implement row-level security where needed
- Audit database access regularly
License
MIT
Support
For issues and questions:
- MCP Protocol: MCP Documentation
- Azure Support: Azure Documentation
- This Implementation: Create an issue in this repository
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.