cuongtl1992_mcp_dbs

cuongtl1992_mcp_dbs

by cuongtl1992
An MCP Server implementation enabling Claude to connect and interact with SQLite, PostgreSQL, SQL Server, and MongoDB databases.

Database Integration for Claude via MCP Server

Overview

The MCP Database Server is a Model Context Protocol (MCP) implementation designed to facilitate integration between Large Language Models (LLMs) and various database systems. It supports SQLite, PostgreSQL, Microsoft SQL Server, and MongoDB, enabling seamless database operations through a unified interface.

Supported Databases

  • SQLite
  • PostgreSQL
  • Microsoft SQL Server
  • MongoDB

Installation

npm install -g mcp-dbs

Usage

The MCP Database Server can be used in two modes:

SSE Mode (Default)

By default, the server runs in SSE (Server-Sent Events) mode on port 3001:

npx mcp-dbs

This will start an HTTP server with an SSE endpoint at http://localhost:3001/mcp.

Custom Port

You can specify a custom port using the --port option:

npx mcp-dbs --port 8080

STDIO Mode

For tools that communicate over standard input/output, you can use the --stdio option:

npx mcp-dbs --stdio

Claude Desktop Integration

You can integrate mcp-dbs with Claude Desktop by adding it to your Claude configuration file.

Configuration Steps

  1. Open or create your Claude Desktop configuration file.
  2. Add the mcp-dbs configuration to the mcpServers section:
{
  "mcpServers": {
    "mcp-dbs": {
      "command": "node",
      "args": [
        "/path/to/your/mcp-dbs/dist/cli.js",
        "--stdio"
      ],
      "env": {
        "MCP_MONGODB_URI": "mongodb://localhost:27017",
        "MCP_MONGODB_DATABASE": "your-database-name"
      }
    }
  }
}

Replace the environment variables with your own database connection details.

Using with Claude

Once configured, Claude will be able to access your database using the MCP tools described below. You can ask Claude to:

  • Connect to your database
  • Execute queries and get results
  • Explore your database schema
  • Work with tables and data

Tools

  • connect-database: Connect to a database
  • disconnect-database: Disconnect from a database
  • execute-query: Execute a query and return results
  • execute-update: Execute a query without returning results

Resources

  • database-schema: Get the full database schema
  • table-schema: Get the schema for a specific table
  • tables-list: Get a list of all tables

Using Environment Variables for Configuration

You can configure your database connections using environment variables:

SQLite

export MCP_SQLITE_FILENAME="path/to/database.db"
export MCP_SQLITE_CREATE_IF_NOT_EXISTS="true"

PostgreSQL

export MCP_POSTGRES_HOST="your-postgres-host"
export MCP_POSTGRES_PORT="5432"
export MCP_POSTGRES_DATABASE="your-database-name"
export MCP_POSTGRES_USER="your-username"
export MCP_POSTGRES_PASSWORD="your-password"
export MCP_POSTGRES_SSL="false"

SQL Server

export MCP_MSSQL_SERVER="your-server-address"
export MCP_MSSQL_PORT="1433"
export MCP_MSSQL_DATABASE="your-database-name"
export MCP_MSSQL_USER="your-username"
export MCP_MSSQL_PASSWORD="your-password"
export MCP_MSSQL_ENCRYPT="true"
export MCP_MSSQL_TRUST_SERVER_CERTIFICATE="true"

MongoDB

export MCP_MONGODB_URI="mongodb://localhost:27017"
export MCP_MONGODB_DATABASE="your-database-name"
export MCP_MONGODB_MAX_POOL_SIZE="10"
export MCP_MONGODB_USE_UNIFIED_TOPOLOGY="true"

MCP Tools

The server exposes the following MCP tools:

connect-database

Connect to a database.

Parameters:

  • connectionId: A unique identifier for the connection
  • type: Database type (sqlite, postgres, mssql, or mongodb)

disconnect-database

Disconnect from a database.

Parameters:

  • connectionId: The connection ID to disconnect

execute-query

Execute a query that returns results.

Parameters:

  • connectionId: The connection ID
  • query: SQL query or MongoDB aggregation pipeline (as JSON string)
  • params: (Optional) Array of parameters for the query. For MongoDB, the first parameter is the collection name.

execute-update

Execute a query that doesn't return results (INSERT, UPDATE, DELETE).

Parameters:

  • connectionId: The connection ID
  • query: SQL query or MongoDB command (as JSON string)
  • params: (Optional) Array of parameters for the query. For MongoDB, the first parameter is the collection name.

MCP Resources

The server exposes the following MCP resources:

Database Schema

URI: database://{connectionId}/schema

Returns schema information about the database, including all tables and their columns.

Table Schema

URI: database://{connectionId}/tables/{tableName}

Returns schema information about a specific table, including its columns.

Tables List

URI: database://{connectionId}/tables

Returns a list of all tables in the database.

Development

Testing

Run the tests:

npm test

Support the Project

If you find this project helpful, consider buying me a coffee!

Buy Me A Coffee QR Code

Scan the QR code above or click here to support the development of this project.

License

MIT

Features & Capabilities

Categories
mcp_server model_context_protocol typescript javascript claude sqlite postgresql sql_server mongodb api_integration database_management

Implementation Details

Stats

0 Views
14 GitHub Stars

Repository Info

cuongtl1992 Organization

Similar MCP Servers

continuedev_continue by continuedev
25049
21423
9300