Simple Snowflake MCP
This server provides comprehensive Snowflake database integration through MCP tools for SQL execution, metadata discovery, and data analysis.
Core Capabilities:
SQL Execution - Execute arbitrary SQL queries with results in structured format or markdown, with configurable read-only mode enforcement
Metadata Discovery - List and explore warehouses, databases, schemas, tables, and views with detailed information
View Operations - Query views with row limiting, describe view structures including columns and SQL definitions
Advanced Features - Validate SQL syntax, explain query execution plans, show query history, get warehouse status, and extract sample data
Configuration & Deployment:
Flexible Configuration - Customize behavior through YAML config files with environment variable overrides, controlling logging, query limits, timeouts, and MCP features
Multiple Deployment Options - Run locally, in Docker containers, or integrate with Claude Desktop and VS Code
Advanced MCP Protocol Support - Real-time resource subscriptions, dynamic resource discovery, and comprehensive error handling
Key Tools:
execute-snowflake-sql/execute-query- SQL execution with different output formatslist-snowflake-warehouses/list-databases/list-views- Metadata explorationdescribe-view/query-view- View analysis and querying
The server supports experimental MCP features like resource subscriptions and completion support, with detailed debugging capabilities through MCP Inspector.
Supports configuration through environment variables loaded from .env files, allowing users to store Snowflake credentials and connection parameters securely.
Formats query results in Markdown format, making the data more readable and structured when displayed in supported interfaces.
Provides tools for interacting with Snowflake databases, including executing SQL queries, listing warehouses, databases, and views, describing view details, and querying views with options for read-only mode and formatted results.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Simple Snowflake MCPshow me the first 10 rows from the sales_data table"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Simple Snowflake MCP server
Enhanced Snowflake MCP Server with comprehensive configuration system and full MCP protocol compliance.
A production-ready MCP server that provides seamless Snowflake integration with advanced features including configurable logging, resource subscriptions, and comprehensive error handling. Designed to work seamlessly behind corporate proxies.
For release details, see CHANGELOG.md.
Tools
The server exposes the following MCP tools to interact with Snowflake:
Database Operations:
execute-snowflake-sql: Executes a SQL query on Snowflake and returns the result. Supports
json(default),markdown, andcsvoutput via theformatargument.execute-query: Executes a SQL query with server-enforced read-only protection. In read-only mode (the default) only
SELECT,SHOW,DESCRIBE,EXPLAIN, andWITHstatements (without DML) are allowed. Read-only mode is governed solely by server configuration and cannot be relaxed by the caller. Supports alimit, anoffsetfor paging, andmarkdown(default)/json/csvoutput viaformat. When a result is truncated the response includes theoffsetfor the next page.
Discovery and Metadata:
get-connection-info: Returns current Snowflake connection information and server status.
list-snowflake-warehouses: Lists available Data Warehouses (DWH) on Snowflake. Pass
include_details: falsefor names only.list-databases: Lists all accessible Snowflake databases. Supports a
patternfilter (wildcards) andinclude_details.list-schemas: Lists schemas in a
database. Supports apatternfilter (wildcards) andinclude_details.list-tables: Lists tables in a
database/schema. Supports apatternfilter (wildcards) andinclude_details.list-views: Lists views in a
database/schema. Supports apatternfilter (wildcards) andinclude_details.describe-table: Returns the columns and types of a
database/schema/table(works for views too). Supportsjson(default)/markdown/csvviaformat.query-view: Reads rows from a
database/schema/view(or table) by name, with the same server-enforced read-only protection and row limiting asexecute-query. Supports alimit, anoffsetfor paging, andmarkdown(default)/json/csvviaformat.export-schema: Exports hierarchical schema metadata (databases → schemas → tables/views → columns). Supports
json(default),yaml, andsqlviaformat, an optionaldatabasefilter, and opt-ininclude_data_samples(table rows only, max 3 rows per table).
Notes (in-memory session state):
add-note: Adds or updates a note (
name,content) kept in server memory for the session.delete-note: Deletes an existing note by
name.list-notes: Lists current note names in sorted order.
get-note: Returns the note payload (
name,content) for a given note name.
Prompts
The server also exposes MCP prompts that bundle server context into ready-to-use messages:
summarize-notes: Summarizes the stored notes. Arguments:
style(brief/detailed/executive),format(text/markdown/json).analyze-snowflake-schema: Produces a schema-analysis prompt. Arguments:
database(optional focus),focus(tables/views/functions/all).generate-sql-query: Helps draft a SQL query from a natural-language goal. Arguments:
intent(required),complexity(simple/intermediate/advanced).troubleshoot-connection: Builds a connection-troubleshooting prompt. Arguments:
error_message(optional).
🔒 Security Model
This server executes client-supplied SQL against Snowflake using a single set of credentials. Treat the MCP client as untrusted (an LLM can be prompt-injected) and deploy accordingly.
The real security boundary is a least-privilege Snowflake role, not the server's keyword filter. The built-in read-only check is defense-in-depth only. Always connect with a role scoped to exactly what you need.
Required deployment posture:
Use a least-privilege, read-only Snowflake role. For read-only deployments, grant only
USAGE/SELECT(and the relevantSHOW/DESCRIBEvisibility) — noINSERT/UPDATE/DELETE/DDL/GRANT. If the role cannot write, no bypass of the keyword filter can cause damage.Keep
read_only: true(the default). Read-only mode is governed solely by server configuration / theMCP_READ_ONLYenvironment variable. It is not client-controllable — there is noread_onlytool argument.Set a statement timeout and rate limit (see
config.yaml) to bound runaway or abusive queries and warehouse-credit consumption.
What the server enforces:
Read-only mode applies to every SQL-executing tool through a single guard; comments are stripped, multi-statement input and CTE-fronted DML (e.g.
WITH ... DELETE) are rejected.pattern/databasearguments are validated against a strict allow-list before being placed intoLIKEclauses;limitis coerced to a bounded integer and applied at the driver, never concatenated into SQL.Row-producing reads without an explicit
LIMITare capped atdefault_query_limitrows (applied at the driver). When a result is capped the response includes an explicit "results were truncated" notice — rows are never dropped silently. Pass a largerlimit(up tomax_query_limit) or add your ownLIMITclause to retrieve more.Snowflake errors are not returned verbatim to the client; a generic message with a reference id is returned and full detail is logged server-side.
Query text is not logged at
INFO(only a length + hash); full SQL isDEBUG-only.
Related MCP server: mcp-server-motherduck
🆕 Configuration System
The server now includes a comprehensive YAML-based configuration system that allows you to customize all aspects of the server behavior.
Configuration File Structure
Create a config.yaml file in your project root:
# Logging Configuration
logging:
level: INFO # DEBUG, INFO, WARNING, ERROR, CRITICAL (overridable via LOG_LEVEL)
format: "%(asctime)s - %(name)s - %(levelname)s - %(message)s"
file_logging:
enabled: false # Set to true to enable file logging
filename: "logs/server.log" # Must resolve under repository ./logs/
max_bytes: 10485760 # Rotate after 10 MB
backup_count: 5
# Server Configuration
server:
name: "simple_snowflake_mcp"
version: "0.4.0"
description: "Enhanced Snowflake MCP Server with full protocol compliance"
connection:
test_on_startup: true
timeout: 30
# Snowflake Configuration
snowflake:
# Read-only mode is read from here (and the MCP_READ_ONLY env var), NOT from
# the server block. Set to false to allow write operations.
read_only: true
default_query_limit: 1000
max_query_limit: 50000
statement_timeout_seconds: 300
connection_reuse: true
# Security controls
security:
rate_limit:
enabled: true
max_calls: 60
window_seconds: 60
notes:
max_count: 100
max_content_length: 10000
# MCP Protocol Settings
mcp:
experimental_features:
resource_subscriptions: true # Enable resource change notifications
completion_support: false # Set to true when MCP version supports it
notifications:
resources_changed: true
tools_changed: true
prompts_changed: trueUsing Custom Configuration
You can specify a custom configuration file using the CONFIG_FILE environment variable:
Windows:
set CONFIG_FILE=config_debug.yaml
python -m simple_snowflake_mcpLinux/macOS:
CONFIG_FILE=config_production.yaml python -m simple_snowflake_mcpConfiguration Override Priority
Configuration values are resolved in this order (highest to lowest priority):
Environment variables (e.g.,
LOG_LEVEL,MCP_READ_ONLY)Custom configuration file (via
CONFIG_FILE)Default
config.yamlfileBuilt-in defaults
🚀 Quick Install
Method 1: Install with uvx (Recommended)
# Install and run directly
uvx simple-snowflake-mcpMethod 2: Install from source
# Clone the repo
git clone https://github.com/YannBrrd/simple_snowflake_mcp
cd simple_snowflake_mcp
# Install with uv (creates a venv automatically)
uv sync
# Run
uv run simple-snowflake-mcpMethod 3: Development
# Install with development dependencies
uv sync --all-extras
# Run the tests
uv run pytest
# Lint with ruff
uv run ruff check .
uv run ruff format .Configuration Claude Desktop
On MacOS: ~/Library/Application\ Support/Claude/claude_desktop_config.json
On Windows: %APPDATA%/Claude/claude_desktop_config.json
"mcpServers": {
"simple_snowflake_mcp": {
"command": "uv",
"args": [
"--directory",
".",
"run",
"simple_snowflake_mcp"
]
}
}"mcpServers": {
"simple_snowflake_mcp": {
"command": "uvx",
"args": [
"simple_snowflake_mcp"
]
}
}Docker Setup
Prerequisites
Docker and Docker Compose installed on your system
Your Snowflake credentials
Quick Start with Docker
Clone the repository
git clone <your-repo> cd simple_snowflake_mcpSet up environment variables
cp .env.example .env # Edit .env with your Snowflake credentialsBuild and run with Docker Compose
# Build the Docker image docker-compose build # Start the service docker-compose up -d # View logs docker-compose logs -f
Docker Commands
Using Docker Compose directly:
# Build the image
docker-compose build
# Start in production mode
docker-compose up -d
# Start in development mode (with volume mounts for live code changes)
docker-compose --profile dev up simple-snowflake-mcp-dev -d
# View logs
docker-compose logs -f
# Stop the service
docker-compose down
# Clean up (remove containers, images, and volumes)
docker-compose down --rmi all --volumes --remove-orphansUsing the provided Makefile (Windows users can use make with WSL or install make for Windows):
# See all available commands
make help
# Build and start
make build
make up
# Development mode
make dev-up
# View logs
make logs
# Clean up
make cleanDocker Configuration
The Docker setup includes:
Dockerfile: Multi-stage build with Python 3.11 slim base image
docker-compose.yml: Service definition with environment variable support
.dockerignore: Optimized build context
Makefile: Convenient commands for Docker operations
Environment Variables
All Snowflake configuration can be set via environment variables:
Required:
SNOWFLAKE_USER: Your Snowflake usernameSNOWFLAKE_PASSWORD: Your Snowflake passwordSNOWFLAKE_ACCOUNT: Your Snowflake account identifier
Optional:
SNOWFLAKE_WAREHOUSE: Warehouse nameSNOWFLAKE_DATABASE: Default databaseSNOWFLAKE_SCHEMA: Default schemaMCP_READ_ONLY: Set to "TRUE" for read-only mode (default: TRUE)
Configuration System (v0.2.0):
CONFIG_FILE: Path to custom configuration file (default: config.yaml)LOG_LEVEL: Override logging level (DEBUG, INFO, WARNING, ERROR, CRITICAL)
Development Mode
For development, use the development profile which mounts your source code:
docker-compose --profile dev up simple-snowflake-mcp-dev -dThis allows you to make changes to the code without rebuilding the Docker image.
Development
Installing dependencies
# Sync all dependencies (prod + dev)
uv sync --all-extras
# Update dependencies
uv lock --upgrade
# Add a new dependency
uv add <package-name>
# Add a dev dependency
uv add --dev <package-name>Build and Publish
# Build
uv build
# Publish to PyPI
uv publish --token $UV_PUBLISH_TOKENCI
GitHub Actions CI runs on pushes to main and on pull requests via .github/workflows/ci.yml:
uv run ruff check .
uv run ruff format --check .
uv run pytestDebugging with MCP Inspector
Since MCP servers run over stdio, debugging can be challenging. For the best debugging experience, we strongly recommend using the MCP Inspector.
You can launch the MCP Inspector via npm with this command:
npx @modelcontextprotocol/inspector uv run simple-snowflake-mcpUpon launching, the Inspector will display a URL that you can access in your browser to begin debugging.
New Feature: Snowflake SQL Execution
The server exposes an MCP tool execute-snowflake-sql to execute a SQL query on Snowflake and return the result.
Usage
Call the MCP tool execute-snowflake-sql with a sql argument containing the SQL query to execute. The result will be returned as a list of dictionaries (one per row).
Example:
{
"name": "execute-snowflake-sql",
"arguments": { "sql": "SELECT CURRENT_TIMESTAMP;" }
}The result will be returned in the MCP response.
Installation and configuration in VS Code
Clone the project and install dependencies
git clone https://github.com/YannBrrd/simple_snowflake_mcp cd simple_snowflake_mcp # Install with uv (creates a venv automatically) uv sync --all-extrasConfigure Snowflake access
Copy
.env.exampleto.envand fill in your credentials:SNOWFLAKE_USER=... SNOWFLAKE_PASSWORD=... SNOWFLAKE_ACCOUNT=... # SNOWFLAKE_WAREHOUSE Optional: Snowflake warehouse name # SNOWFLAKE_DATABASE Optional: default database name # SNOWFLAKE_SCHEMA Optional: default schema name # MCP_READ_ONLY=true|false Optional: true/false to force read-only mode
Configure the server (v0.2.0)
If no
config.yamlis present, the server uses its built-in defaults (no file is created automatically)Customize logging, limits, and MCP features by editing
config.yaml(an example is provided in the repository)Use
CONFIG_FILE=custom_config.yamlto specify a different file (resolved within the repository only, to prevent path traversal)
Configure VS Code for MCP debugging
The
.vscode/mcp.jsonfile is already present:{ "servers": { "simple-snowflake-mcp": { "type": "stdio", "command": "uv", "args": ["run", "simple-snowflake-mcp"] } } }Open the command palette (Ctrl+Shift+P), type
MCP: Start Server, and selectsimple-snowflake-mcp.
Usage
The exposed MCP tools let you query Snowflake (list-databases, list-snowflake-warehouses, execute-query, execute-snowflake-sql, export-schema, etc.).
For more examples, see the MCP protocol documentation: https://github.com/modelcontextprotocol/create-python-server
Enhanced MCP Features (v0.2.0)
Advanced MCP Protocol Support
This server now implements comprehensive MCP protocol features:
🔔 Resource Subscriptions
Real-time notifications when Snowflake resources change
Automatic updates for database schema changes
Tool availability notifications
📋 Enhanced Resource Management
Dynamic resource discovery and listing
Detailed resource metadata and descriptions
Resource templates for browsing the object hierarchy by URI (
snowflake://database/{database}/schemas,snowflake://database/{database}/schema/{schema}/tables,snowflake://table/{database}/{schema}/{table})Argument completion for prompts and resource templates (live database/ schema/table name suggestions)
Client-controlled log verbosity via the MCP
logging/setLevelrequest
⚡ Performance & Reliability
Configurable query limits and a server-side statement timeout
Comprehensive error handling with generic client messages and a server-side reference id
Single-connection reuse with automatic reconnect on a stale connection
🔧 Development Features
Multiple output formats (JSON, Markdown, CSV)
In-process rate limiting across all tool calls
Comprehensive logging with configurable levels (and an explicit truncation notice on capped results)
MCP Capabilities Advertised
The server advertises these MCP capabilities:
✅ Tools: Full tool execution with comprehensive schemas
✅ Resources: Dynamic resource discovery, subscriptions, and templates
✅ Prompts: Enhanced prompts with resource integration
✅ Notifications: Real-time change notifications
✅ Completion: Argument completion for prompts and resource templates
✅ Logging: Client-controlled log level via
logging/setLevel
Supported MCP Functions
The server exposes the following MCP tools (see the Tools section above for full argument details):
Database Operations:
execute-snowflake-sql: Executes a SQL query and returns results as JSON, markdown, or CSV
execute-query: Query execution with read-only protection, row limit, and multiple output formats
Discovery and Metadata:
get-connection-info: Current connection information and server status
list-snowflake-warehouses: Lists available Data Warehouses with status
list-databases: Lists all accessible databases, with optional pattern filtering
export-schema: Exports hierarchical schema metadata in JSON, YAML, or SQL format (with optional capped table samples)
Session Notes:
add-note / delete-note / list-notes / get-note: Manage in-memory notes for the session
The server also implements MCP resources (Snowflake objects with subscription support) and prompts. For parameter schemas, inspect handle_list_tools in src/simple_snowflake_mcp/server.py.
🚀 Getting Started Examples
Basic Usage
# Execute a simple query
{
"name": "execute-query",
"arguments": {
"sql": "SELECT CURRENT_TIMESTAMP;",
"format": "markdown"
}
}
# List all databases
{
"name": "list-databases",
"arguments": {}
}Advanced Configuration
# config_production.yaml
logging:
level: WARNING
file_logging:
enabled: true
filename: "logs/mcp_server.log"
snowflake:
# Keep true unless the connecting Snowflake role is itself read-only.
read_only: true
default_query_limit: 5000
max_query_limit: 100000
statement_timeout_seconds: 120
connection_reuse: true
security:
rate_limit:
enabled: true
max_calls: 60
window_seconds: 60
notes:
max_count: 100
max_content_length: 10000
mcp:
experimental_features:
resource_subscriptions: trueDebugging and Troubleshooting
Enable Debug Logging:
# Method 1: Environment variable
export LOG_LEVEL=DEBUG
python -m simple_snowflake_mcp
# Method 2: Custom config file
export CONFIG_FILE=config_debug.yaml
python -m simple_snowflake_mcpCommon Issues:
Connection errors: Check your Snowflake credentials and network connectivity
Permission errors: Ensure your user has appropriate Snowflake privileges
Query limits: Adjust
default_query_limitin config.yaml for large result setsMCP compatibility: Update to latest MCP client version for full feature support
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/YannBrrd/simple_snowflake_mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server