Azure SQL MCP Server
Enables querying, exploring, and interacting with Azure SQL databases through MCP-compatible clients like Claude Desktop.
README
Azure SQL MCP Server
A Model Context Protocol (MCP) server for connecting to Azure SQL databases. This server provides tools to query, explore, and interact with Azure SQL databases through Claude Desktop or any MCP-compatible client.
Features
- Execute arbitrary SQL queries
- Browse database tables and schemas
- Get sample data from tables
- Configuration validation
- Azure Active Directory authentication via DefaultAzureCredential
Prerequisites
Before starting, ensure you have these installed:
- Python 3.11+ - Managed via pyenv (recommended) or system Python
- Node.js 18+ - For MCP Inspector (Download)
- uv - Fast Python package manager (Install guide)
- ODBC Driver 17 for SQL Server - (Download)
- Azure credentials - Azure CLI, VS Code, or Managed Identity
- npx - Comes with Node.js (used to run MCP Inspector)
Installing Prerequisites
Install Node.js and npx
# Windows: Download from https://nodejs.org/
# Or use winget
winget install OpenJS.NodeJS
# macOS
brew install node
# Linux
curl -fsSL https://deb.nodesource.com/setup_18.x | sudo -E bash -
sudo apt-get install -y nodejs
# Verify installation
node --version
npx --version
Install uv
# Windows (PowerShell)
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
# macOS/Linux
curl -LsSf https://astral.sh/uv/install.sh | sh
# Verify installation
uv --version
Install pyenv (Optional but Recommended)
# Windows
# Use pyenv-win: https://github.com/pyenv-win/pyenv-win
# macOS
brew install pyenv
# Linux
curl https://pyenv.run | bash
Installation & Setup
1. Clone the Repository
git clone <your-repo-url>
cd mcp_component
2. Set Python Version (if using pyenv)
# Set global Python version
pyenv global 3.11.4
# Or set local version for this project only
pyenv local 3.11.4
# Verify
python --version
3. Create and Activate Virtual Environment
# Create virtual environment using uv
uv venv
# Activate the virtual environment
# Windows (PowerShell)
.venv\Scripts\activate
# Windows (CMD)
.venv\Scripts\activate.bat
# macOS/Linux
source .venv/bin/activate
4. Install Dependencies
# Option 1: Sync from pyproject.toml (recommended)
uv sync
# Option 2: Install from requirements.txt
uv pip install -r requirements.txt
uv add -r requirements.txt
# Verify installation
uv pip list
Pro Tip: If you need to add new packages later:
# Add a single package uv add package-name # Add multiple packages from requirements.txt uv add -r requirements.txt
5. Configure Environment Variables
Create a .env file in the project root:
# Copy the example
cp .env.example .env
# Or create manually
Edit .env with your Azure SQL credentials:
SERVER_NAME=your-server.database.windows.net
DATABASE=your-database-name
Example:
SERVER_NAME=mycompany-sql.database.windows.net
DATABASE=Northwind
Note: You can test the server without a real database! Leave the default values to test the MCP server functionality. The tools will indicate configuration is needed, but the server will run fine.
6. Authenticate with Azure
Make sure you're authenticated with Azure using one of these methods:
# Option 1: Azure CLI (recommended for local testing)
az login
# Option 2: Use environment variables
# Add to .env file:
# AZURE_TENANT_ID=your-tenant-id
# AZURE_CLIENT_ID=your-client-id
# AZURE_CLIENT_SECRET=your-client-secret
# Option 3: Use VS Code Azure Account extension
# (automatically works if signed in)
Verify Azure authentication:
az account show
Testing with MCP Inspector
The MCP Inspector is an interactive tool for testing your MCP server before connecting it to Claude Desktop.
Install and Run Inspector
# Run the inspector (npx will auto-install it if needed)
npx @modelcontextprotocol/inspector uv --directory . run server.py
What happens:
npxdownloads and runs the MCP Inspector (first time only)- Opens automatically in your default browser at
http://localhost:5173 - Shows all available tools in the left sidebar
- Displays request/response JSON for debugging
Inspector Interface Overview
- Left Panel: List of available tools
- Center Panel: Tool parameters and execution
- Right Panel: JSON request/response output
- Bottom: Server logs and errors (stderr)
Testing Workflow
-
Start the Inspector (command above)
-
Check Configuration:
- Click on
check_database_configtool - Click "Run Tool"
- Verify your database settings
- Click on
-
Test Tools:
- Try
get_tablesto see available tables - Use
get_table_schemawith a table name - Execute
get_sample_datato preview data
- Try
-
Debug Issues:
- Check the stderr output for error messages
- Verify your
.envfile is correct - Ensure Azure authentication is working
Available Tools
1. check_database_config
Check if your database credentials are properly configured.
No parameters required
Example Response:
{
"configured": true,
"message": "Configuration OK",
"server_name": "myserver.database.windows.net",
"database": "Northwind"
}
2. execute_query
Execute any SQL query against your database.
Parameters:
query(string): SQL query to execute
Example:
{
"query": "SELECT TOP 5 * FROM Customers ORDER BY CompanyName"
}
Response:
{
"rows": 5,
"columns": ["CustomerID", "CompanyName", "ContactName"],
"data": [...]
}
3. get_tables
Get a list of all tables in the database.
No parameters required
Example Response:
{
"tables": [
{
"schema": "dbo",
"name": "Customers",
"full_name": "dbo.Customers"
},
{
"schema": "dbo",
"name": "Orders",
"full_name": "dbo.Orders"
}
]
}
4. get_table_schema
Get detailed schema information for a specific table.
Parameters:
table_name(string): Name of the table (e.g., "Customers" or "dbo.Customers")
Example:
{
"table_name": "Customers"
}
Response:
{
"table": "Customers",
"columns": [
{
"COLUMN_NAME": "CustomerID",
"DATA_TYPE": "nchar",
"IS_NULLABLE": "NO",
"COLUMN_DEFAULT": null,
"CHARACTER_MAXIMUM_LENGTH": 5
}
]
}
5. get_sample_data
Get sample rows from a table.
Parameters:
table_name(string): Name of the tablelimit(integer, optional): Number of rows (default: 5, max: 100)
Example:
{
"table_name": "Customers",
"limit": 10
}
Response:
{
"table": "Customers",
"sample_rows": 10,
"total_columns": 11,
"columns": ["CustomerID", "CompanyName", ...],
"data": [...]
}
Using with Claude Desktop
Once you've tested with the Inspector, connect to Claude Desktop:
1. Locate Claude Desktop Config
Windows: %APPDATA%\Claude\claude_desktop_config.json
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Linux: ~/.config/Claude/claude_desktop_config.json
2. Add Server Configuration
Edit or create the config file:
Windows:
{
"mcpServers": {
"azure-sql": {
"command": "uv",
"args": [
"--directory",
"C:\\Users\\YourUsername\\path\\to\\mcp_component",
"run",
"server.py"
]
}
}
}
macOS/Linux:
{
"mcpServers": {
"azure-sql": {
"command": "uv",
"args": [
"--directory",
"/Users/yourname/projects/mcp_component",
"run",
"server.py"
]
}
}
}
Important: Replace the path with your actual absolute project path!
3. Restart Claude Desktop
After saving the config:
- Completely quit Claude Desktop (not just close the window)
- Restart the application
- Look for the 🔌 plug icon in the interface
- Click it to verify "azure-sql" server is connected (green indicator)
4. Test with Claude
Try asking Claude:
- "Can you check if my database is configured?"
- "What tables are available in my database?"
- "Show me the schema for the Customers table"
- "Get me 5 sample rows from the Orders table"
- "Execute this query: SELECT COUNT(*) FROM Products"
Project Structure
mcp_component/
├── .env # Environment variables (create this - not in git)
├── .env.example # Example environment file
├── .gitignore # Git ignore rules
├── .python-version # Python version for pyenv
├── pyproject.toml # Project metadata and dependencies
├── requirements.txt # Python dependencies
├── uv.lock # Dependency lock file
├── server.py # Main entry point wrapper
├── mcp_server/
│ ├── __init__.py
│ └── server.py # MCP server implementation
├── README.md # This file
└── .venv/ # Virtual environment (created by uv venv)
Troubleshooting
"npx: command not found"
Cause: Node.js/npm is not installed or not in PATH
Solution:
# Verify Node.js installation
node --version
npm --version
# If not installed, install Node.js from https://nodejs.org/
# Or use a package manager (see Prerequisites section)
"uv: command not found"
Cause: uv is not installed or not in PATH
Solution:
# Windows (PowerShell as Administrator)
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
# Then restart your terminal
# Verify
uv --version
Inspector shows "error" notification
Cause: Server crashed during startup or has import errors
Solution:
- Check the stderr output in the Inspector console for detailed error messages
- Common issues:
- Python dependencies not installed: Run
uv sync - Wrong Python version: Run
python --version(need 3.11+) - Import errors: Make sure you're running from the project root
- Azure auth issues: Run
az login
- Python dependencies not installed: Run
"Database not configured" error
Expected behavior if you haven't set up your .env file with real credentials. The server will still run—you just won't be able to query data until you configure it.
Solution: Update .env with your actual Azure SQL Server details:
SERVER_NAME=your-actual-server.database.windows.net
DATABASE=your-actual-database-name
Connection timeout or authentication errors
Solutions:
-
Firewall: Verify your Azure SQL firewall allows your IP address
# Check current IP curl https://api.ipify.org # Add it to Azure SQL firewall rules in Azure Portal -
Authentication: Run
az loginto authenticateaz login az account show -
Permissions: Check that your Azure account has access to the database
az sql db show --resource-group <rg-name> --server <server-name> --name <db-name> -
ODBC Driver: Verify ODBC Driver 17 is installed
# Windows - Check installed ODBC drivers Get-OdbcDriver # Should show "ODBC Driver 17 for SQL Server"
Tools not appearing in Claude Desktop
Solutions:
-
Config path: Double-check the config file is in the correct location:
# Windows - Open config directory explorer %APPDATA%\Claude # Verify claude_desktop_config.json exists -
Absolute path: Ensure the project path in
argsis absolute and correct// ❌ Wrong - relative path "C:\\mcp_component" // ✅ Correct - absolute path "C:\\Users\\YourName\\Projects\\mcp_component" -
Restart properly: Completely quit Claude Desktop (not just minimize)
- Windows: Right-click system tray icon → Exit
- macOS: Cmd+Q or Claude → Quit Claude
-
Check logs: Look for errors in Claude Desktop logs:
- Windows:
%APPDATA%\Claude\logs - macOS:
~/Library/Logs/Claude
- Windows:
-
Test with Inspector first: Verify the server works:
npx @modelcontextprotocol/inspector uv --directory . run server.py
"ODBC Driver not found"
Solution: Install ODBC Driver 17 for SQL Server:
Windows:
# Download and run installer from:
# https://go.microsoft.com/fwlink/?linkid=2249004
# Verify installation
Get-OdbcDriver | Where-Object {$_.Name -like "*SQL Server*"}
macOS:
brew tap microsoft/mssql-release https://github.com/Microsoft/homebrew-mssql-release
brew update
brew install msodbcsql17
# Verify
odbcinst -q -d
Linux (Ubuntu/Debian):
curl https://packages.microsoft.com/keys/microsoft.asc | sudo apt-key add -
curl https://packages.microsoft.com/config/ubuntu/$(lsb_release -rs)/prod.list | sudo tee /etc/apt/sources.list.d/mssql-release.list
sudo apt-get update
sudo ACCEPT_EULA=Y apt-get install -y msodbcsql17
# Verify
odbcinst -q -d
"Module not found" errors
Solution:
# Ensure virtual environment is activated
# Windows
.venv\Scripts\activate
# macOS/Linux
source .venv/bin/activate
# Reinstall dependencies
uv sync
# Or
uv pip install -r requirements.txt
Development
Adding Custom Tools
You can add your own tools to mcp_server/server.py:
@mcp.tool()
async def my_custom_tool(param: str) -> str:
"""Description of what this tool does
Args:
param: Description of the parameter
"""
try:
engine = await get_azure_engine()
# Your custom logic here
query = text("SELECT * FROM MyTable WHERE column = :param")
with engine.connect() as connection:
result = connection.execute(query, {"param": param})
data = [dict(row) for row in result]
return json.dumps({"result": data}, indent=2)
except Exception as e:
return json.dumps({"error": str(e)}, indent=2)
Best Practices:
- Always wrap tools in try/except
- Return JSON strings (use
json.dumps()) - Use parameterized queries to prevent SQL injection
- Add descriptive docstrings for Claude to understand the tool
- Test new tools in the Inspector before using in Claude Desktop
Updating Dependencies
# Add a new package
uv add package-name
# Update all packages
uv sync --upgrade
# Remove a package
uv remove package-name
Authentication Details
This server uses DefaultAzureCredential from Azure Identity SDK, which tries multiple authentication methods in order:
- Environment variables -
AZURE_TENANT_ID,AZURE_CLIENT_ID,AZURE_CLIENT_SECRET - Managed Identity - Works automatically in Azure services (App Service, Functions, VMs)
- Azure CLI - Uses
az logincredentials (✅ recommended for local development) - Visual Studio Code - Uses VS Code Azure Account extension
- Interactive browser - Falls back to browser login
For local testing (recommended):
az login
For production (recommended):
- Use Managed Identity in Azure services
- Or use Service Principal with environment variables
Contributing
Contributions are welcome! Please:
- Fork the repository
- Create a feature branch (
git checkout -b feature/XXX-XXX) - Make your changes
- Test with the MCP Inspector
- Commit your changes (
git commit -m 'Add XXXX feature') - Push to the branch (
git push origin feature/XXX-XXX) - Open a Pull Request
Resources
- MCP Documentation: https://modelcontextprotocol.io
- MCP Inspector: https://github.com/modelcontextprotocol/inspector
- Azure SQL Documentation: https://learn.microsoft.com/en-us/azure/azure-sql/
- uv Documentation: https://github.com/astral-sh/uv
- FastMCP Documentation: https://github.com/jlowin/fastmcp
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.