Enables querying MariaDB databases to list databases and tables, inspect table schemas, and execute read-only SQL queries with token-optimized formatting.
Provides tools to interact with MySQL instances, allowing users to list databases and tables, describe table structures, and perform custom read-only SELECT queries.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@MariaDB MCP Servershow me the schema of the users table"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MariaDB MCP Server
🚀 Serveur MCP (Model Context Protocol) optimisé pour interroger une instance MariaDB/MySQL locale avec une consommation minimale de tokens.
✨ Caractéristiques
🔍 4 outils MCP : list_databases, list_tables, describe_table, query_database
🛡️ Sécurisé : Bloque automatiquement les requêtes destructives (DROP, DELETE, etc.)
⚡ Ultra-optimisé : Format de sortie compact (75-95% de tokens économisés vs JSON)
🔌 Compatible : Fonctionne avec Warp, Claude Desktop, et tout client MCP
📊 Formats lisibles : Sortie en texte brut avec séparateurs
\net|
📦 Installation
Prérequis
Node.js 18+
MariaDB ou MySQL installé et accessible
Un client MCP (Warp, Claude Desktop, etc.)
Étapes
⚙️ Configuration
1. Variables d'environnement
Créer un fichier .env :
Éditer .env avec vos identifiants :
2. Configuration Warp
Ajouter dans votre configuration Warp (~/.config/warp/mcp_config.json ou équivalent) :
3. Configuration Claude Desktop
Ajouter dans ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) ou équivalent :
Redémarrer votre client MCP après la configuration.
🔧 Outils disponibles
list_databases
Liste toutes les bases de données disponibles.
Exemple de sortie :
list_tables
Liste toutes les tables d'une base de données.
Paramètres :
database(optionnel) : Nom de la base
Exemple de sortie :
describe_table
Affiche la structure complète d'une table.
Paramètres :
table(requis) : Nom de la tabledatabase(optionnel) : Nom de la base
Exemple de sortie :
query_database
Exécute une requête SQL SELECT personnalisée.
Paramètres :
query(requis) : Requête SQL (SELECT, SHOW, DESCRIBE uniquement)
Exemple de sortie :
🛡️ Sécurité
Protection intégrée : Le serveur bloque automatiquement les requêtes destructives :
❌ DROP, DELETE, TRUNCATE
❌ ALTER, CREATE
❌ INSERT, UPDATE
✅ Seules les requêtes en lecture sont autorisées (SELECT, SHOW, DESCRIBE)
🧪 Test manuel
Pour tester le serveur en ligne de commande :
📊 Optimisation des tokens
Ce serveur utilise des formats de sortie ultra-compacts :
Type de données | Format JSON | Format optimisé | Économie |
Listes simples |
|
| ~93% |
Tables |
|
| ~75% |
Structures | JSON indenté | Pipe-separated | ~80% |
Impact : Réduction drastique des coûts d'API et des temps de réponse ! 🚀
🗺️ Roadmap & Futures évolutions
Version 1.1 (Court terme)
Support des connexions distantes sécurisées (SSH tunnel)
Pagination automatique pour les grandes requêtes
Option
--limitpour limiter le nombre de résultatsCache des schémas de tables pour réduire les requêtes
Support des transactions en lecture seule
Version 1.2 (Moyen terme)
Mode d'écriture optionnel avec confirmation explicite
Export des résultats (CSV, JSON)
Statistiques d'utilisation et monitoring
Support de multiples connexions simultanées
Interface web pour visualiser les résultats
Version 2.0 (Long terme)
Support PostgreSQL et SQLite
Génération automatique de requêtes SQL à partir de langage naturel
Analyse et suggestions d'optimisation de schéma
Détection automatique des relations entre tables
Mode "explain" pour les performances des requêtes
Snapshots de bases pour comparaisons
Idées à explorer
Plugin pour VSCode
Support des vues matérialisées
Système de permissions granulaire par table
Audit logs des requêtes exécutées
Support des procédures stockées (lecture seule)
🤝 Contribution
Les contributions sont les bienvenues !
Fork le projet
Créer une branche (
git checkout -b feature/amelioration)Commit vos changements (
git commit -m 'Ajout fonctionnalité')Push vers la branche (
git push origin feature/amelioration)Ouvrir une Pull Request
📝 License
MIT License - voir le fichier LICENSE pour plus de détails.
🙏 Remerciements
Model Context Protocol par Anthropic
mariadb - Client Node.js pour MariaDB
📧 Contact
Pour toute question ou suggestion, ouvrez une issue.