MotherDuck

MotherDuck avatar

by MotherDuck

databaseanalyticsduckdbofficial

Query and analyze data with MotherDuck and local DuckDB

What is MotherDuck

MotherDuck MCP Server

An MCP server implementation that integrates MotherDuck and local DuckDB, providing SQL analytics capabilities to Claude.

Features

  • Hybrid execution: query data from both cloud-based MotherDuck and local DuckDB
  • Cloud storage integration: access data stored in Amazon S3 or other cloud storage thanks to MotherDuck's integrations
  • Data sharing: create and share databases
  • SQL analytics: use DuckDB's SQL dialect to query any size of data directly from Claude
  • Serverless architecture: run analytics without needing to configure instances or clusters

Components

Prompts

The server provides one prompt:

  • duckdb-motherduck-initial-prompt: A prompt to initialize a connection to DuckDB or MotherDuck and start working with it

Tools

The server offers one tool:

  • query: Execute a SQL query on the MotherDuck/DuckDB database
    • Inputs:
      • query (string, required): The SQL query to execute

All interactions with both DuckDB and MotherDuck are done through writing SQL queries.

Getting Started

Prerequisites

  • A MotherDuck account (sign up at motherduck.com)
  • A MotherDuck access token
  • uv installed, you can install it using pip install uv or brew install uv

If you plan to use MotherDuck MCP with Claude Desktop, you will also need Claude Desktop installed.

Setting up your MotherDuck token

  1. Sign up for a MotherDuck account
  2. Generate an access token via the MotherDuck UI
  3. Store the token securely for use in the configuration

Usage with Claude Desktop

  1. Install Claude Desktop from claude.ai/download if you haven't already

  2. Open the Claude Desktop configuration file:

  • To quickly access it or create it the first time, open the Claude Desktop app, select Settings, and click on the "Developer" tab, finally click on the "Edit Config" button.
  • Add the following configuration to your claude_desktop_config.json:
"mcpServers": {
  "mcp-server-motherduck": {
    "command": "uvx",
    "args": [
      "mcp-server-motherduck",
      "--db-path",
      "md:",
      "--motherduck-token",
      "<YOUR_MOTHERDUCK_TOKEN_HERE>",
    ],
  }
}

Important Notes:

  • Replace YOUR_MOTHERDUCK_TOKEN_HERE with your actual MotherDuck token
  • Replace YOUR_HOME_FOLDER_PATH with the path to your home directory (needed by DuckDB for file operations). For example, on macOS, it would be /Users/your_username
  • The HOME environment variable is required for DuckDB to function properly.

Example Queries

Once configured, you can ask Claude to run queries like:

  • "Create a new database and table in MotherDuck"
  • "Query data from my local CSV file"
  • "Join data from my local DuckDB database with a table in MotherDuck"
  • "Analyze data stored in Amazon S3"

Testing

The server is designed to be run by tools like Claude Desktop and Cursor, but you can start it manually for testing purposes. When testing the server manually, you can specify which database to connect to using the --db-path parameter:

  1. Default MotherDuck database:

    • To connect to the default MotherDuck database, you will need to pass the auth token using the --motherduck-token parameter.
    uvx mcp-server-motherduck --db-path md: --motherduck-token <your_motherduck_token>
    
  2. Specific MotherDuck database:

    uvx mcp-server-motherduck --db-path md:your_database_name --motherduck-token <your_motherduck_token>
    
  3. Local DuckDB database:

    uvx mcp-server-motherduck --db-path /path/to/your/local.db
    
  4. In-memory database:

    uvx mcp-server-motherduck --db-path :memory:
    

If you don't specify a database path but have set the motherduck_token environment variable, the server will automatically connect to the default MotherDuck database (md:).

Running in SSE mode

The server could also be run ing SSE mode using supergateway by running the following command:

npx -y supergateway --stdio "uvx mcp-server-motherduck --db-path md: --motherduck-token <your_motherduck_token>"

And you can point your clients such as Claude Desktop, Cursor to this endpoint.

Troubleshooting

  • If you encounter connection issues, verify your MotherDuck token is correct
  • For local file access problems, ensure the --home-dir parameter is set correctly
  • Check that the uvx command is available in your PATH
  • If you encounter spawn uvx ENOENT errors, try specifying the full path to uvx (output of which uvx)
  • In version previous for v0.4.0 we used environment variables, now we use parameters

License

This MCP server is licensed under the MIT License. This means you are free to use, modify, and distribute the software, subject to the terms and conditions of the MIT License. For more details, please see the LICENSE file in the project repository.

How to Use

Leave a Comment

Comments section will be available soon. Stay tuned!

Frequently Asked Questions

What is MCP?

MCP (Model Context Protocol) is an open protocol that standardizes how applications provide context to LLMs. Think of MCP like a USB-C port for AI applications, providing a standardized way to connect AI models to different data sources and tools.

What are MCP Servers?

MCP Servers are lightweight programs that expose specific capabilities through the standardized Model Context Protocol. They act as bridges between LLMs like Claude and various data sources or services, allowing secure access to files, databases, APIs, and other resources.

How do MCP Servers work?

MCP Servers follow a client-server architecture where a host application (like Claude Desktop) connects to multiple servers. Each server provides specific functionality through standardized endpoints and protocols, enabling Claude to access data and perform actions through the standardized protocol.

Are MCP Servers secure?

Yes, MCP Servers are designed with security in mind. They run locally with explicit configuration and permissions, require user approval for actions, and include built-in security features to prevent unauthorized access and ensure data privacy.

Related MCP Servers

MasterGo MCP Server avatar

MasterGo MCP Server

MasterGo Magic MCP 是一个独立的 MCP (Model Context Protocol) 服务,用于连接 MasterGo 设计工具与 AI 模型。它允许 AI 模型直接从 MasterGo 设计文件中获取 DSL 数据。

DesignMastergoofficial
Filesystem MCP Server avatar

Filesystem MCP Server

A core MCP server that provides filesystem access capabilities for Claude. Enables secure reading, writing, and management of files on your local system with granular permission controls.

filesystemcoreofficial
Brave Search MCP avatar

Brave Search MCP

Integrate Brave Search capabilities into Claude through MCP. Enables real-time web searches with privacy-focused results and comprehensive web coverage.

searchapiofficial
PostgreSQL MCP Server avatar

PostgreSQL MCP Server

A Model Context Protocol server that provides read-only access to PostgreSQL databases. This server enables LLMs to inspect database schemas and execute read-only queries.

databasepostgresqlcommunity
MongoDB MCP Server avatar

MongoDB MCP Server

A Model Context Protocol server that provides access to MongoDB databases. This server enables LLMs to inspect collection schemas and execute MongoDB operations.

databasemongodbcommunity
GitHub MCP Server avatar

GitHub MCP Server

MCP Server for the GitHub API, enabling file operations, repository management, search functionality, and more.

databasemongodbcommunity
EverArt MCP Server avatar

EverArt MCP Server

Image generation server for Claude Desktop using EverArt's API.

databasemongodbcommunity
Magic MCP avatar

Magic MCP

Create crafted UI components inspired by the best 21st.dev design engineers.

uidesigncomponents
Apify avatar

Apify

Use 3,000+ pre-built cloud tools to extract data from websites, e-commerce, social media, search engines, maps, and more

scrapingdata-extractioncloud
mcp server axiom avatar

mcp server axiom

A Model Context Protocol server implementation for Axiom that enables AI agents to query your data using Axiom Processing Language (APL).Query and analyze your Axiom logs, traces, and all other event data in natural language,

logginganalyticsmonitoring

Submit Your MCP Server

Share your MCP server with the community

Submit Now