PlanetMarc/SqlDb-MCP-Server
If you are the rightful owner of SqlDb-MCP-Server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
A Model Context Protocol (MCP) server implementation that provides secure access to SQL Server databases.
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 .
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