- Explore MCP Servers
- SB-MCP
Sb Mcp
What is Sb Mcp
SB-MCP is a Supabase Model Context Protocol (MCP) server designed for CRUD operations and Edge Functions, enabling interaction between large language models (LLMs) like Claude and Supabase for managing Postgres tables.
Use cases
Use cases for SB-MCP include building applications that require real-time data manipulation, integrating LLMs for intelligent data queries, and developing backend services that leverage Supabase for data management.
How to use
To use SB-MCP, install it via npm or clone the repository. Configure your Supabase credentials in a .env file, and start the server. You can also integrate it with Claude or use it as a standalone server for database operations.
Key features
Key features of SB-MCP include database operations such as querying data with filters, inserting, updating, deleting data, and listing tables. It also supports integration with Claude for enhanced functionality.
Where to use
SB-MCP can be used in various fields such as web development, data analysis, and application backend services where interaction with a Postgres database is required.
Clients Supporting MCP
The following are the main client software that supports the Model Context Protocol. Click the link to visit the official website for more information.
Overview
What is Sb Mcp
SB-MCP is a Supabase Model Context Protocol (MCP) server designed for CRUD operations and Edge Functions, enabling interaction between large language models (LLMs) like Claude and Supabase for managing Postgres tables.
Use cases
Use cases for SB-MCP include building applications that require real-time data manipulation, integrating LLMs for intelligent data queries, and developing backend services that leverage Supabase for data management.
How to use
To use SB-MCP, install it via npm or clone the repository. Configure your Supabase credentials in a .env file, and start the server. You can also integrate it with Claude or use it as a standalone server for database operations.
Key features
Key features of SB-MCP include database operations such as querying data with filters, inserting, updating, deleting data, and listing tables. It also supports integration with Claude for enhanced functionality.
Where to use
SB-MCP can be used in various fields such as web development, data analysis, and application backend services where interaction with a Postgres database is required.
Clients Supporting MCP
The following are the main client software that supports the Model Context Protocol. Click the link to visit the official website for more information.
Content
Supabase MCP Server
A Model Context Protocol (MCP) server that allows Claude and other LLMs to interact with Supabase to perform CRUD operations on Postgres tables.
Features
- Database operations:
- Query data with filters
- Insert data
- Update data
- Delete data
- List tables
Prerequisites
- Node.js (v16 or newer)
- npm or yarn
- Supabase project with API keys
Installation
Option 1: Install from npm (recommended)
The package is published on npm! You can install it globally with:
npm install -g supabase-mcp
Or locally in your project:
npm install supabase-mcp
Option 2: Clone the repository
git clone https://github.com/Cappahccino/SB-MCP.git
cd SB-MCP
npm install
npm run build
Configuration
Create a .env file with your Supabase credentials:
# Supabase credentials SUPABASE_URL=your_supabase_project_url SUPABASE_ANON_KEY=your_supabase_anon_key SUPABASE_SERVICE_ROLE_KEY=your_supabase_service_role_key # MCP server configuration MCP_SERVER_PORT=3000 MCP_SERVER_HOST=localhost MCP_API_KEY=your_secret_api_key
Usage with Claude
Claude requires a specific transport mode for compatibility. This package provides a dedicated binary for Claude integration:
In Claude Desktop MCP Config
Make sure you set the required environment variables in the configuration. Claude will use the stdio transport for communication.
Manual Testing with Claude Binary
For testing outside of Claude, you can run:
npm run start:claude
Or if installed globally:
supabase-mcp-claude
Usage as a Standalone Server
After installing globally:
supabase-mcp
This will start the MCP server at http://localhost:3000 (or the port specified in your .env file).
Usage in Your Code
You can also use supabase-mcp as a library in your own Node.js projects:
import { createServer, mcpConfig, validateConfig } from 'supabase-mcp';
// Validate configuration
validateConfig();
// Create the server
const app = createServer();
// Start the server
app.listen(mcpConfig.port, mcpConfig.host, () => {
console.log(`Supabase MCP server running at http://${mcpConfig.host}:${mcpConfig.port}`);
});
Troubleshooting
Common Issues and Solutions
1. “Port XXXX is already in use”
The HTTP server attempts to find an available port automatically. You can manually specify a different port in your .env file by changing the MCP_SERVER_PORT value.
2. “Missing required environment variables”
Make sure you have a proper .env file with all the required values or that you’ve set the environment variables in your system.
3. “TypeError: Class constructor Server cannot be invoked without ‘new’”
If you see this error, you may be running an older version of the package. Update to the latest version:
npm install -g supabase-mcp@latest
4. JSON parsing errors with Claude
Make sure you’re using the Claude-specific binary (supabase-mcp-claude) instead of the regular HTTP server (supabase-mcp).
5. Request timed out with Claude
This usually means Claude initiated the connection but the server was unable to respond in time. Check:
- Are your Supabase credentials correct?
- Is your server setup properly and running?
- Is there anything blocking the connection?
Tools Reference
Database Tools
-
queryDatabase
- Parameters:
table(string): Name of the table to queryselect(string, optional): Comma-separated list of columns (default: “*”)query(object, optional): Filter conditions
- Parameters:
-
insertData
- Parameters:
table(string): Name of the tabledata(object or array of objects): Data to insert
- Parameters:
-
updateData
- Parameters:
table(string): Name of the tabledata(object): Data to update as key-value pairsquery(object): Filter conditions for the update
- Parameters:
-
deleteData
- Parameters:
table(string): Name of the tablequery(object): Filter conditions for deletion
- Parameters:
-
listTables
- Parameters: None
Version History
- 1.0.0: Initial release
- 1.0.1: Added automatic port selection
- 1.0.2: Fixed protocol compatibility issues
- 1.0.3: Added JSON-RPC support
- 1.1.0: Complete rewrite using official MCP SDK
- 1.2.0: Added separate Claude transport and fixed port conflict issues
- 1.3.0: Updated for improved compatibility with TypeScript projects
- 1.4.0: Fixed Claude stdio transport integration based on Supabase community best practices
- 1.5.0: Removed Edge Function support to improve stability and focus on database operations
License
MIT
Dev Tools Supporting MCP
The following are the main code editors that support the Model Context Protocol. Click the link to visit the official website for more information.










