Skip to main content
Glama
patrickfreyer

snowflake-mcp

Node-based Snowflake MCP

License: MIT CI

A TypeScript-based MCP (Model Context Protocol) server that enables Large Language Models (LLMs) like Claude to directly query and interact with Snowflake databases.

๐ŸŒŸ Features

  • ๐Ÿ”Œ Easy Integration - Simple setup with Claude Desktop, Cursor, or any MCP-compatible tool

  • ๐Ÿ”’ Secure - Multiple authentication methods including environment variables and key-pair authentication

  • ๐Ÿš€ High Performance - Built with TypeScript and the native Snowflake Node.js driver

  • ๐Ÿ“Š Full Database Access - Query, explore schemas, list tables, and analyze data

  • ๐Ÿ› ๏ธ Developer Friendly - Comprehensive TypeScript types and error handling

Related MCP server: Snowflake MCP Server

๐Ÿ“‹ Prerequisites

  • Node.js 18 or higher

  • npm or yarn

  • Snowflake account with appropriate access permissions

  • MCP-compatible client (Claude Desktop, Cursor, Continue, etc.)

๐Ÿš€ Quick Start

Installation Options

The easiest way to install this MCP server in Claude Desktop is using the pre-built MCPB package:

  1. Download the latest release:

    • Go to Releases

    • Download the snowflake-mcp-v1.0.0.mcpb file

  2. Install in Claude Desktop:

    • Open Claude Desktop

    • Navigate to Settings โ†’ Developer โ†’ MCP Servers

    • Click "Install from file"

    • Select the downloaded .mcpb file

    • Configure your Snowflake credentials when prompted

Option 2: Build MCPB Package from Source

# Clone the repository
git clone https://github.com/patrickfreyer/mcp-server-snowflake.git
cd mcp-server-snowflake

# Install dependencies
npm install

# Build the TypeScript server
npm run build

# Create the MCPB package
./build-mcpb.sh

# The package will be created as snowflake-mcp-v1.0.0.mcpb
# Install this file in Claude Desktop as described above

Option 3: Manual Installation (For Development)

# Clone the repository
git clone https://github.com/patrickfreyer/mcp-server-snowflake.git
cd mcp-server-snowflake

# Install dependencies
npm install

# Build the server
npm run build

Configuration

Configuration depends on your installation method:

For MCPB Package Users

When you install the MCPB package, Claude Desktop will automatically prompt you for:

  • Snowflake Account (e.g., your-account.region.provider)

  • Warehouse name

  • Username (typically your email)

  • Password

  • Role (optional)

  • Database (optional)

  • Schema (optional)

These credentials are securely stored in Claude Desktop's configuration.

For Manual Installation

  1. Set up environment variables:

# Copy the example environment file
cp .env.example .env

# Edit .env with your Snowflake credentials
SNOWFLAKE_ACCOUNT=your-account.region.provider
SNOWFLAKE_USER=your.email@company.com
SNOWFLAKE_PASSWORD=your-password
SNOWFLAKE_WAREHOUSE=YOUR_WAREHOUSE  # Optional
SNOWFLAKE_DATABASE=YOUR_DATABASE     # Optional
SNOWFLAKE_SCHEMA=YOUR_SCHEMA        # Optional
SNOWFLAKE_ROLE=YOUR_ROLE           # Optional
  1. Configure your MCP client:

Claude Desktop

Add to ~/Library/Application Support/Claude/claude_desktop_config.json:

{
  "mcpServers": {
    "snowflake": {
      "command": "node",
      "args": ["/absolute/path/to/mcp-server-snowflake/dist/index.js"],
      "env": {
        "SNOWFLAKE_ACCOUNT": "your-account.region.provider",
        "SNOWFLAKE_USER": "your.email@company.com",
        "SNOWFLAKE_PASSWORD": "your-password",
        "SNOWFLAKE_WAREHOUSE": "YOUR_WAREHOUSE",
        "SNOWFLAKE_DATABASE": "YOUR_DATABASE",
        "SNOWFLAKE_SCHEMA": "YOUR_SCHEMA",
        "SNOWFLAKE_ROLE": "YOUR_ROLE"
      }
    }
  }
}

Cursor

Add to Cursor settings:

{
  "mcp.servers": {
    "snowflake": {
      "command": "node",
      "args": ["/path/to/mcp-server-snowflake/dist/index.js"],
      "env": {
        "SNOWFLAKE_ACCOUNT": "your-account",
        "SNOWFLAKE_USER": "your-user",
        "SNOWFLAKE_PASSWORD": "your-password"
      }
    }
  }
}

๐Ÿ“š Available Tools

The MCP server provides the following tools for interacting with Snowflake:

read_query

Execute SELECT queries on your Snowflake database.

// Example
{
  "query": "SELECT * FROM customers LIMIT 10"
}

list_databases

List all available databases in your Snowflake account.

list_schemas

List all schemas in a specific database.

// Example
{
  "database": "MY_DATABASE"  // Optional
}

list_tables

List all tables in a specific schema.

// Example
{
  "database": "MY_DATABASE",  // Optional
  "schema": "MY_SCHEMA"       // Optional
}

describe_table

Get detailed information about a table's structure.

// Example
{
  "table_name": "DATABASE.SCHEMA.TABLE"
}

๐Ÿ”’ Security

Environment Variables

The recommended approach for credentials:

export SNOWFLAKE_ACCOUNT="your-account"
export SNOWFLAKE_USER="your-user"
export SNOWFLAKE_PASSWORD="your-password"

Key-Pair Authentication (Production)

For production environments, we recommend using key-pair authentication:

  1. Generate a key pair

  2. Configure your Snowflake user with the public key

  3. Update the server configuration to use the private key

File Permissions

Secure your configuration files:

chmod 600 ~/.env
chmod 600 ~/Library/Application\ Support/Claude/claude_desktop_config.json

๐Ÿ“ฆ Building MCPB Packages

The MCPB (MCP Bundle) format allows for easy distribution and installation of MCP servers in Claude Desktop.

Building a Package

# Ensure the project is built
npm run build

# Create the MCPB package
./build-mcpb.sh

This will create a snowflake-mcp-v1.0.0.mcpb file containing:

  • Compiled server code

  • Manifest with configuration schema

  • Production dependencies

  • Installation metadata

Package Contents

The MCPB package includes:

  • manifest.json - Defines configuration parameters and server entry point

  • dist/ - Compiled TypeScript server code

  • node_modules/ - Production dependencies only

  • README.md - Package documentation

Manifest Configuration

The manifest.json file defines:

  • User configuration parameters (without default values for security)

  • Server entry point and environment variable mapping

  • Tool definitions for Snowflake operations

  • Package metadata (name, version, author, etc.)

๐Ÿงช Development

Setup Development Environment

# Install dependencies
npm install

# Run in development mode
npm run dev

# Run tests
npm test

# Lint code
npm run lint

# Type check
npm run type-check

Project Structure

mcp-server-snowflake/
โ”œโ”€โ”€ src/
โ”‚   โ””โ”€โ”€ index.ts          # Main server implementation
โ”œโ”€โ”€ dist/                 # Compiled JavaScript (generated)
โ”œโ”€โ”€ tests/               # Test files
โ”œโ”€โ”€ .env.example         # Environment variable template
โ”œโ”€โ”€ .github/
โ”‚   โ””โ”€โ”€ workflows/       # CI/CD workflows
โ”œโ”€โ”€ manifest.json        # MCPB package configuration
โ”œโ”€โ”€ build-mcpb.sh        # Script to build MCPB package
โ”œโ”€โ”€ package.json         # Node.js dependencies
โ”œโ”€โ”€ tsconfig.json        # TypeScript configuration
โ”œโ”€โ”€ LICENSE             # MIT License
โ”œโ”€โ”€ CONTRIBUTING.md     # Contribution guidelines
โ””โ”€โ”€ README.md          # This file

๐Ÿค Contributing

We welcome contributions! Please see our Contributing Guide for details.

How to Contribute

  1. Fork the repository

  2. Create your feature branch (git checkout -b feature/AmazingFeature)

  3. Commit your changes (git commit -m 'Add some AmazingFeature')

  4. Push to the branch (git push origin feature/AmazingFeature)

  5. Open a Pull Request

๐Ÿ“ License

This project is licensed under the MIT License - see the LICENSE file for details.

๐Ÿ†˜ Support

If you encounter any issues or have questions:

  1. Check the Troubleshooting section below

  2. Search existing issues

  3. Create a new issue

๐Ÿ”ง Troubleshooting

Common Issues

"Missing required Snowflake configuration"

  • Ensure all required environment variables are set

  • Check for typos in variable names

  • Verify the .env file is in the correct location

Connection Failed

  • Verify your Snowflake account format: account.region.provider

  • Check network connectivity and firewall settings

  • Ensure your IP is whitelisted in Snowflake network policies

Permission Denied

  • Verify your Snowflake role has necessary permissions

  • Check warehouse access rights

  • Ensure database and schema permissions are granted

Debug Mode

Enable verbose logging:

export DEBUG=mcp:*
node dist/index.js

๐Ÿš€ Roadmap

  • Add support for write operations (INSERT, UPDATE, DELETE)

  • Implement connection pooling

  • Add support for Snowflake stored procedures

  • Create a web-based configuration UI

  • Add support for multiple Snowflake accounts

  • Implement query result caching

  • Add data visualization capabilities

๐Ÿ‘ฅ Authors

  • Patrick Freyer - Initial work

๐Ÿ™ Acknowledgments

  • Anthropic for the MCP protocol specification

  • Snowflake for their excellent Node.js SDK

  • The open-source community for continuous support and contributions

๐Ÿ“Š Stats

GitHub stars GitHub forks GitHub watchers


Made with โค๏ธ by Patrick Freyer

Install Server
F
license - not found
A
quality
D
maintenance

Maintenance

โ€“Maintainers
โ€“Response time
โ€“Release cycle
โ€“Releases (12mo)
Commit activity

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

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/patrickfreyer/mcp-server-snowflake'

If you have feedback or need assistance with the MCP directory API, please join our Discord server