Track MCP LogoTrack MCP
Track MCP LogoTrack MCP

The world's largest repository of Model Context Protocol servers. Discover, explore, and submit MCP tools.

Product

  • Categories
  • Top MCP
  • New & Updated
  • Submit MCP

Company

  • About

Legal

  • Privacy Policy
  • Terms of Service
  • Cookie Policy

© 2026 TrackMCP. All rights reserved.

Built with ❤️ by Krishna Goyal

    Mcp Server Motherduck

    MCP server for DuckDB and MotherDuck Python-based implementation.

    362 stars
    Python
    Updated Nov 4, 2025
    ai
    duckdb
    motherduck

    Table of Contents

    • Remote vs Local MCP
    • Quick Start
    • Connecting to In-Memory DuckDB (Dev Mode)
    • Connecting to a Local DuckDB File in Read-Only Mode
    • Connecting to MotherDuck in Read-Write Mode
    • Client Setup
    • Tools
    • Securing for Production
    • Command Line Parameters
    • Environment Variables
    • Troubleshooting
    • Resources
    • Development
    • Release Process
    • License

    Table of Contents

    • Remote vs Local MCP
    • Quick Start
    • Connecting to In-Memory DuckDB (Dev Mode)
    • Connecting to a Local DuckDB File in Read-Only Mode
    • Connecting to MotherDuck in Read-Write Mode
    • Client Setup
    • Tools
    • Securing for Production
    • Command Line Parameters
    • Environment Variables
    • Troubleshooting
    • Resources
    • Development
    • Release Process
    • License

    Documentation

    DuckDB / MotherDuck Local MCP Server

    SQL analytics and data engineering for AI Assistants and IDEs.

    ---

    Connect AI assistants to your data using DuckDB's powerful analytical SQL engine. Supports connecting to local DuckDB files, in-memory databases, S3-hosted databases, and MotherDuck. Allows executing SQL read- and write-queries, browsing database catalogs, and switching between different database connections on-the-fly.

    Looking for a fully-managed remote MCP server for MotherDuck? → Go to the MotherDuck Remote MCP docs

    Remote vs Local MCP

    **Remote MCP**Local MCP (this repo)
    HostingHosted by MotherDuckRuns locally/self-hosted
    SetupZero-setupRequires local installation
    AccessRead-write supportedRead-write supported
    Local filesystem-Query across local and remote databases, ingest data from / export data to local filesystem

    📝 Migrating from v0.x?

    - Read-only by default: The server now runs in read-only mode by default. Add --read-write to enable write access. See Securing for Production.

    - Default database changed: --db-path default changed from md: to :memory:. Add --db-path md: explicitly for MotherDuck.

    - MotherDuck read-only requires read-scaling token: MotherDuck connections in read-only mode require a read-scaling token. Regular tokens require --read-write.

    Quick Start

    Prerequisites: Install uv via pip install uv or brew install uv

    Connecting to In-Memory DuckDB (Dev Mode)

    json
    {
      "mcpServers": {
        "DuckDB (in-memory, r/w)": {
          "command": "uvx",
          "args": ["mcp-server-motherduck", "--db-path", ":memory:", "--read-write", "--allow-switch-databases"]
        }
      }
    }

    Full flexibility with no guardrails — read-write access and the ability to switch to any database (local files, S3, or MotherDuck) at runtime.

    Connecting to a Local DuckDB File in Read-Only Mode

    json
    {
      "mcpServers": {
        "DuckDB (read-only)": {
          "command": "uvx",
          "args": ["mcp-server-motherduck", "--db-path", "/absolute/path/to/your.duckdb"]
        }
      }
    }

    Connects to a specific DuckDB file in read-only mode. Won't hold on to the file lock, so convenient to use alongside a write connection to the same DuckDB file. You can also connect to remote DuckDB files on S3 using s3://bucket/path.duckdb — see Environment Variables for S3 authentication. If you're considering third-party access to the MCP, see Securing for Production.

    Connecting to MotherDuck in Read-Write Mode

    json
    {
      "mcpServers": {
        "MotherDuck (local, r/w)": {
          "command": "uvx",
          "args": ["mcp-server-motherduck", "--db-path", "md:", "--read-write"],
          "env": {
            "motherduck_token": ""
          }
        }
      }
    }

    See Command Line Parameters for more options, Securing for Production for deployment guidance, and Troubleshooting if you encounter issues.

    Client Setup

    ClientConfig LocationOne-Click Install
    Claude DesktopSettings → Developer → Edit Config.mcpb (MCP Bundle)
    Claude CodeUse CLI commands below-
    Codex CLIUse CLI commands below-
    CursorSettings → MCP → Add new global MCP server
    VS CodeCtrl+Shift+P → "Preferences: Open User Settings (JSON)"Install with UV in VS Code

    Any MCP-compatible client can use this server. Add the JSON configuration from Quick Start to your client's MCP config file. Consult your client's documentation for the config file location.

    Claude Code CLI commands

    In-Memory DuckDB (Dev Mode):

    bash
    claude mcp add --scope user duckdb --transport stdio -- uvx mcp-server-motherduck --db-path :memory: --read-write --allow-switch-databases

    Local DuckDB (Read-Only):

    bash
    claude mcp add --scope user duckdb --transport stdio -- uvx mcp-server-motherduck --db-path /absolute/path/to/db.duckdb

    MotherDuck (Read-Write):

    bash
    claude mcp add --scope user motherduck --transport stdio --env motherduck_token=YOUR_TOKEN -- uvx mcp-server-motherduck --db-path md: --read-write

    Codex CLI commands

    In-Memory DuckDB (Dev Mode):

    bash
    codex mcp add duckdb -- uvx mcp-server-motherduck --db-path :memory: --read-write --allow-switch-databases

    Local DuckDB (Read-Only):

    bash
    codex mcp add duckdb -- uvx mcp-server-motherduck --db-path /absolute/path/to/db.duckdb

    MotherDuck (Read-Write):

    bash
    codex mcp add motherduck --env motherduck_token=YOUR_TOKEN -- uvx mcp-server-motherduck --db-path md: --read-write

    Tools

    ToolDescriptionRequired InputsOptional Inputs
    execute_queryExecute SQL query (DuckDB dialect)sql-
    list_databasesList all databases (useful for MotherDuck or multiple attached DBs)--
    list_tablesList tables and views-database, schema
    list_columnsList columns of a table/viewtabledatabase, schema
    switch_database_connection*Switch to different databasepathcreate_if_not_exists

    *Requires --allow-switch-databases flag

    All tools return JSON. Results are limited to 1024 rows / 50,000 chars by default (configurable via --max-rows, --max-chars).

    Securing for Production

    When giving third parties access to a self-hosted MCP server, read-only mode alone is not sufficient — it still allows access to the local filesystem, changing DuckDB settings, and other potentially sensitive operations.

    For production deployments with third-party access, we recommend **MotherDuck Remote MCP** — zero-setup, read-write capable, and hosted by MotherDuck.

    Self-hosting MotherDuck MCP: Fork this repo and customize as needed. Use a **service account with read-scaling tokens and enable SaaS mode** to restrict local file access.

    Self-hosting DuckDB MCP: Use --init-sql to apply security settings. See the Securing DuckDB guide for available options.

    Command Line Parameters

    ParameterDefaultDescription
    --db-path:memory:Database path: local file (absolute), md: (MotherDuck), or s3:// URL
    --motherduck-tokenmotherduck_token env varMotherDuck access token
    --read-writeFalseEnable write access
    --motherduck-saas-modeFalseMotherDuck SaaS mode (restricts local access)
    --allow-switch-databasesFalseEnable switch_database_connection tool
    --max-rows1024Max rows returned
    --max-chars50000Max characters returned
    --query-timeout-1Query timeout in seconds (-1 = disabled)
    --init-sqlNoneSQL to execute on startup
    --motherduck-connection-parameterssession_hint=mcp&dbinstance_inactivity_ttl=0sAdditional MotherDuck connection string parameters (key=value pairs separated by &)
    --ephemeral-connectionsTrueUse temporary connections for read-only local files
    --transportstdioTransport type: stdio or http
    --stateless-httpFalseFor protocol compatibility only (e.g. with AWS Bedrock AgentCore Runtime). Server still maintains global state via the shared DatabaseClient.
    --port8000Port for HTTP transport
    --host127.0.0.1Host for HTTP transport

    Environment Variables

    VariableDescription
    motherduck_token or MOTHERDUCK_TOKENMotherDuck access token (alternative to --motherduck-token)
    HOMEUsed by DuckDB for extensions and config. Override with --home-dir if not set.
    AWS_ACCESS_KEY_IDAWS access key for S3 database connections
    AWS_SECRET_ACCESS_KEYAWS secret key for S3 database connections
    AWS_SESSION_TOKENAWS session token for temporary credentials (IAM roles, SSO, EC2 instance profiles)
    AWS_DEFAULT_REGIONAWS region for S3 connections

    Troubleshooting

    • **spawn uvx ENOENT**: Specify full path to uvx (run which uvx to find it)
    • File locked: Make sure --ephemeral-connections is turned on (default: true) and that you're not connected in read-write mode

    Resources

    • MotherDuck MCP Documentation
    • Close the Loop: Faster Data Pipelines with MCP, DuckDB & AI (Blog)
    • Faster Data Pipelines with MCP and DuckDB (YouTube)

    Development

    To run from source:

    json
    {
      "mcpServers": {
        "Local DuckDB (Dev)": {
          "command": "uv",
          "args": ["--directory", "/path/to/mcp-server-motherduck", "run", "mcp-server-motherduck", "--db-path", "md:"],
          "env": {
            "motherduck_token": ""
          }
        }
      }
    }

    Release Process

    1. Run the Release New Version GitHub Action

    2. Enter version in MAJOR.MINOR.PATCH format

    3. The workflow bumps version, publishes to PyPI/MCP registry, and creates the GitHub release with MCPB package

    License

    MIT License - see LICENSE file.

    ##

    mcp-name: io.github.motherduckdb/mcp-server-motherduck

    Similar MCP

    Based on tags & features

    • BI

      Biomcp

      Python·
      327
    • SE

      Serena

      Python·
      14.5k
    • MA

      Manim Mcp Server

      Python·
      490
    • VI

      Video Editing Mcp

      Python·
      218

    Trending MCP

    Most active this week

    • PL

      Playwright Mcp

      TypeScript·
      22.1k
    • SE

      Serena

      Python·
      14.5k
    • MC

      Mcp Playwright

      TypeScript·
      4.9k
    • MC

      Mcp Server Cloudflare

      TypeScript·
      3.0k
    View All MCP Servers

    Similar MCP

    Based on tags & features

    • BI

      Biomcp

      Python·
      327
    • SE

      Serena

      Python·
      14.5k
    • MA

      Manim Mcp Server

      Python·
      490
    • VI

      Video Editing Mcp

      Python·
      218

    Trending MCP

    Most active this week

    • PL

      Playwright Mcp

      TypeScript·
      22.1k
    • SE

      Serena

      Python·
      14.5k
    • MC

      Mcp Playwright

      TypeScript·
      4.9k
    • MC

      Mcp Server Cloudflare

      TypeScript·
      3.0k