SQL Server Setup Guide
This guide provides instructions for setting up and using the SQL Server adapter with the MCP Database Server.
Prerequisites
- Access to a SQL Server instance (2012 or later)
- Node.js 18 or later
- Required permissions to connect to the SQL Server database
Installation
- Follow the main installation steps in the README.md file
- Ensure the mssql package is installed:
npm install mssql
npm install @types/mssql --save-dev
Authentication Options
The SQL Server adapter supports multiple authentication methods:
SQL Server Authentication
Use the --user and --password parameters to authenticate with SQL Server credentials:
node dist/src/index.js --sqlserver --server myserver --database mydatabase --user myuser --password mypassword
Windows Authentication
Omit the --user and --password parameters to use Windows Authentication (trusted connection):
node dist/src/index.js --sqlserver --server myserver --database mydatabase
Azure Active Directory
For Azure SQL Database with Azure AD authentication, you'll need to set up connection options:
{
  "mcpServers": {
    "sqlserver": {
      "command": "node",
      "args": [
        "/path/to/mcp-database-server/dist/src/index.js",
        "--sqlserver",
        "--server", "myserver.database.windows.net",
        "--database", "mydatabase",
        "--user", "myuser@mydomain.com",
        "--password", "mypassword"
      ]
    }
  }
}
Configuring Claude
Update your Claude configuration file to add SQL Server support:
{
  "mcpServers": {
    "sqlserver": {
      "command": "node",
      "args": [
        "/path/to/mcp-database-server/dist/src/index.js",
        "--sqlserver",
        "--server", "your-server-name",
        "--database", "your-database-name",
        "--user", "your-username",
        "--password", "your-password"
      ]
    }
  }
}
For local SQL Server with Windows Authentication:
{
  "mcpServers": {
    "sqlserver": {
      "command": "node",
      "args": [
        "/path/to/mcp-database-server/dist/src/index.js",
        "--sqlserver",
        "--server", "localhost\\SQLEXPRESS",
        "--database", "your-database-name"
      ]
    }
  }
}
Connection Options
Additional connection options include:
- --port: Specify a non-default port (default is 1433)
- Add --trustServerCertificate trueif you're connecting to a development/test server with a self-signed certificate
Troubleshooting
Common Connection Issues
- 
Login failed for user - Verify username and password
- Check if the SQL Server account is enabled and not locked
 
- 
Cannot connect to server - Ensure SQL Server is running
- Check firewall settings
- Verify server name is correct (including instance name if applicable)
 
- 
SSL errors - Add --trustServerCertificate truefor development environments
 
- Add 
Verifying Connection
You can test your SQL Server connection using the standard SQL Server tools:
- Using SQL Server Management Studio (SSMS)
- Using the sqlcmdutility:sqlcmd -S server_name -d database_name -U username -P password
SQL Syntax Differences
Note that there may be syntax differences between SQLite and SQL Server. Here are some common differences:
- 
String concatenation - SQLite: ||
- SQL Server: +
 
- SQLite: 
- 
Limit/Offset - SQLite: LIMIT x OFFSET y
- SQL Server: OFFSET y ROWS FETCH NEXT x ROWS ONLY
 
- SQLite: 
- 
Date formatting - SQLite: strftime()
- SQL Server: FORMAT()orCONVERT()
 
- SQLite: 
- 
Auto-increment columns - SQLite: INTEGER PRIMARY KEY AUTOINCREMENT
- SQL Server: INT IDENTITY(1,1)
 
- SQLite: 
When using Claude, be aware of these syntax differences when crafting SQL queries.