Provides read-only access to PostgreSQL databases with tools for executing SELECT queries, listing tables, describing table schemas, and running common database information queries. Includes security features that block all write operations (INSERT, UPDATE, DELETE, DROP).
MCP PostgreSQL Server
Un servidor MCP (Model Context Protocol) seguro para acceder a bases de datos PostgreSQL que solo permite consultas SELECT.
🚀 Características
✅ Solo consultas SELECT: Máxima seguridad, no permite INSERT, UPDATE, DELETE u otras operaciones peligrosas
✅ Configuración desde el proyecto: Lee la cadena de conexión desde
MCP_PG_CONNSTRen el archivo.envdel proyecto que está siendo editado (no del servidor MCP)✅ JavaScript puro: No requiere TypeScript ni compilación
✅ Manejo robusto de errores: Logging apropiado y manejo de errores de conexión
✅ Múltiples herramientas útiles: Exploración de esquemas, listado de tablas, y consultas comunes
📁 Concepto importante: Separación de configuración
Este servidor MCP funciona de manera diferente a una aplicación normal:
¿Por qué es así?
El servidor MCP es una herramienta externa que se conecta a tu proyecto
Cada proyecto puede tener su propia base de datos (diferente conexión)
El servidor MCP lee automáticamente el
.envde tu proyecto actualNo necesitas configurar nada en el servidor MCP, solo en tu proyecto
📋 Requisitos previos
Node.js 18 o superior
Una base de datos PostgreSQL accesible
Acceso de lectura a la base de datos
🛠️ Instalación
Clona o descarga el proyecto:
Instala las dependencias:
Configura las variables de entorno EN EL PROYECTO QUE ESTÁS EDITANDO:
⚠️ IMPORTANTE: El archivo .env debe estar en la raíz del proyecto que estás editando, NO en la carpeta del servidor MCP.
En la raíz de tu proyecto (donde tienes tu código fuente), crea un archivo .env:
Ejemplo de estructura:
🚀 Uso
Ejecución del servidor
Configuración en Claude Desktop
Para usar este servidor con Claude Desktop, agrega la siguiente configuración a tu archivo claude_desktop_config.json:
Windows:
macOS/Linux:
Ubicación del archivo de configuración:
Windows:
%APPDATA%\\Claude\\claude_desktop_config.jsonmacOS:
~/Library/Application Support/Claude/claude_desktop_config.json
🔧 Herramientas disponibles
1. execute_select_query
Ejecuta consultas SELECT personalizadas.
Parámetros:
query(string): La consulta SELECT a ejecutarparams(array, opcional): Parámetros para consultas preparadas
Ejemplo:
2. list_tables
Lista todas las tablas disponibles en la base de datos.
Parámetros: Ninguno
3. describe_table
Obtiene información detallada sobre las columnas de una tabla.
Parámetros:
table_name(string): Nombre de la tablaschema_name(string, opcional): Nombre del esquema (por defecto: 'public')
4. execute_common_queries
Ejecuta consultas predefinidas útiles.
Parámetros:
query_type(string): Uno de:database_version: Versión de PostgreSQLcurrent_user: Usuario actualcurrent_database: Base de datos actualtable_sizes: Tamaños de las tablas
🔒 Seguridad
Este servidor implementa múltiples capas de seguridad:
Validación de consultas: Solo permite comandos SELECT
Filtrado de patrones peligrosos: Bloquea INSERT, UPDATE, DELETE, DROP, etc.
Consultas preparadas: Soporte para parámetros seguros
Conexiones seguras: Soporte SSL para conexiones en producción
Consultas permitidas ✅
Consultas bloqueadas ❌
🌍 Variables de entorno
⚠️ Ubicación importante: Estas variables deben estar en el archivo .env en la raíz del proyecto que estás editando, no en la carpeta del servidor MCP.
Variable | Descripción | Ubicación | Ejemplo |
| Cadena de conexión a PostgreSQL | Proyecto editado/.env |
|
| Puerto para servidor HTTP (opcional) | Proyecto editado/.env |
|
| Entorno de ejecución | Proyecto editado/.env |
|
🔄 Ejemplos de cadenas de conexión
PostgreSQL local:
PostgreSQL remoto:
Con SSL:
Con parámetros adicionales:
🐛 Solución de problemas
Error: "MCP_PG_CONNSTR no está definida"
IMPORTANTE: El archivo
.envdebe estar en la raíz del proyecto que estás editando, NO en la carpeta del servidor MCPEl servidor busca en
[directorio-de-tu-proyecto]/.envVerifica que la variable
MCP_PG_CONNSTRestá definida correctamente en ese archivoRevisa el mensaje de error que muestra la ruta exacta donde busca el archivo
Error de conexión a la base de datos
Verifica que PostgreSQL está ejecutándose
Confirma que las credenciales son correctas
Asegúrate de que el usuario tiene permisos de lectura en las tablas
El servidor no aparece en Claude Desktop
Verifica que las rutas en
claude_desktop_config.jsonson absolutas y correctasReinicia Claude Desktop después de modificar la configuración
Revisa los logs de error en la consola
Problemas de permisos
📝 Logs y depuración
El servidor usa console.error() para logging, que es seguro con el transporte STDIO de MCP. Los logs incluyen:
✅ Confirmación de conexión exitosa a PostgreSQL
🔍 Consultas ejecutadas (primeros 100 caracteres)
❌ Errores de conexión y consultas
📊 Información de inicio del servidor
🤝 Contribución
Fork del repositorio
Crea una rama para tu feature (
git checkout -b feature/nueva-funcionalidad)Commit tus cambios (
git commit -am 'Agrega nueva funcionalidad')Push a la rama (
git push origin feature/nueva-funcionalidad)Crea un Pull Request
📄 Licencia
MIT License - ver archivo LICENSE para más detalles.
🔗 Enlaces útiles
📞 Soporte
Si encuentras algún problema o tienes sugerencias, por favor:
Revisa la sección de solución de problemas
Busca en los issues existentes
Crea un nuevo issue si es necesario
⚠️ Recordatorio de seguridad: Este servidor solo permite consultas SELECT para mantener la seguridad de tu base de datos. No modifica, elimina ni altera datos de ninguna manera.