
AnyDB MCP Server
Enables natural language database operations and semantic document search through SQLite and vector database integration. Converts plain English instructions into SQL queries and provides RAG capabilities for uploaded documents.
README
AnyDB MCP Server
A Model Context Protocol (MCP) server that provides intelligent database operations through natural language processing. This server integrates SQLite databases with Ollama for AI-powered SQL generation and execution.
Features
Core Database Operations
- Natural Language to SQL: Convert plain English instructions into SQL queries using Ollama
- Universal Database Operations: Works with any SQLite table/entity without predefined schemas
- MCP Integration: Seamlessly integrates with Claude Desktop and other MCP-compatible clients
- Async Operations: Built on modern Python async/await for high performance
- Safety First: Separate tools for read and write operations
Vector Database & RAG (NEW!)
- File Embedding: Automatically convert files into vector embeddings for semantic search
- Semantic Search: Find relevant content using natural language queries instead of exact keyword matching
- RAG Support: Enable Claude Desktop to answer questions about uploaded documents with context
- Smart Chunking: Intelligently splits large documents into overlapping chunks for better retrieval
- Persistent Storage: ChromaDB-powered vector database with automatic embedding generation
Available Tools
Database Tools
1. query_entity
Query any table with natural language instructions.
Parameters:
entity_name
(required): Name of the table to queryinstruction
(optional): Natural language query instruction (default: "SELECT all records")
Example: Query users table for active accounts
2. insert_entity
Insert records into any table using natural language descriptions.
Parameters:
entity_name
(required): Name of the tabledata
(required): Data to insert (JSON or natural description)
Example: Insert a new user with email and name
3. update_entity
Update records in any table with conditions.
Parameters:
entity_name
(required): Name of the tableinstruction
(required): Update instructionconditions
(optional): WHERE conditions
Example: Update user status to active where email matches
4. delete_entity
Delete records from any table with optional conditions.
Parameters:
entity_name
(required): Name of the tableconditions
(optional): WHERE conditions for deletion
Example: Delete inactive users older than 30 days
5. create_table
Create new tables with AI-generated schemas.
Parameters:
entity_name
(required): Name of the new tableschema_description
(required): Description of table schema
Example: Create a products table with name, price, and category
6. sql_query
Execute raw SQL SELECT queries directly.
Parameters:
query
(required): SQL query to execute
Example: Direct SQL for complex joins and analytics
7. sql_execute
Execute raw SQL modification queries (INSERT, UPDATE, DELETE, CREATE, etc.).
Parameters:
query
(required): SQL query to execute
Example: Direct SQL for complex data modifications
Vector Database Tools (NEW!)
8. add_file_to_vector_db
Add a file to the vector database for semantic search and RAG (Retrieval Augmented Generation).
Parameters:
filename
(required): Name of the filecontent
(required): Content of the file (text)metadata
(optional): Optional metadata for the file
Example: Add a document about machine learning for later semantic search
9. search_vector_db
Search the vector database for relevant file content using semantic similarity.
Parameters:
query
(required): Search query for semantic similaritymax_results
(optional): Maximum number of results to return (default: 5)
Example: Find documents related to "neural networks and AI"
10. list_vector_files
List all files stored in the vector database.
Parameters: None
Example: View all documents available for search
11. remove_file_from_vector_db
Remove a file from the vector database.
Parameters:
filename
(required): Name of the file to remove
Example: Delete outdated documents from the knowledge base
Installation
Prerequisites
- Python 3.8+
- Ollama running locally
- Claude Desktop (for MCP integration)
Setup
- Clone the repository:
git clone https://github.com/iamayuppie/AnyDbApp.git
cd AnyDbApp
- Install dependencies:
pip install -r requirements.txt
- Start Ollama:
ollama serve --port 1434
ollama pull llama3.1 # or your preferred model
- Run the server:
python main.py
Claude Desktop Integration
Add this server to Claude Desktop by editing your config file:
Windows: %APPDATA%\Claude\claude_desktop_config.json
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
{
"mcpServers": {
"anydb": {
"command": "python",
"args": ["C:\\Path\\To\\AnyDbApp\\mcp_server_stdio.py"],
"env": {
"PYTHONPATH": "C:\\Path\\To\\AnyDbApp"
}
}
}
}
Restart Claude Desktop to connect the server.
Configuration
Ollama Settings
Default configuration in mcp_server.py
:
- Host: localhost
- Port: 1434
- Model: llama3.1
Database Settings
- Default DB:
anydb.sqlite
(created automatically) - Location: Same directory as the server
- Type: SQLite with foreign key constraints enabled
Usage Examples
Once integrated with Claude Desktop, you can use natural language:
Database Operations
- "Create a users table with id, name, email, and created_at fields"
- "Show me all active users from the last 30 days"
- "Insert a new product: iPhone 15, price $999, category Electronics"
- "Update all pending orders to processed where amount > 100"
- "Delete test users where email contains 'test'"
Vector Database & File Operations
- "Add this document to the knowledge base" (when attaching a file in Claude Desktop)
- "Search for information about machine learning algorithms"
- "Find documents related to user authentication and security"
- "What does the uploaded contract say about payment terms?"
- "Show me all documents I've added to the database"
- "Remove the old privacy policy document"
Architecture
┌─────────────────┐ ┌──────────────┐ ┌─────────────────┐
│ Claude │────│ MCP Server │────│ Ollama │
│ Desktop │ │ (stdio) │ │ (localhost) │
│ + File Upload │ │ │ │ │
└─────────────────┘ └──────────────┘ └─────────────────┘
│
▼
┌──────────────────┐
│ Dual Storage │
│ │
│ ┌──────────────┐ │
│ │ SQLite │ │ ← Structured Data
│ │ Database │ │
│ └──────────────┘ │
│ │
│ ┌──────────────┐ │
│ │ ChromaDB │ │ ← Document Embeddings
│ │ Vector Store │ │ & Semantic Search
│ └──────────────┘ │
└──────────────────┘
Development
Project Structure
AnyDbApp/
├── main.py # Clean entry point with startup info
├── mcp_server.py # MCP server setup and tool routing
├── dbtool.py # Database operations and SQL tools
├── filetool.py # Vector database and file operations
├── requirements.txt # Python dependencies
├── pyproject.toml # Project metadata
└── README.md # This file
Key Components
Core Modules:
- main.py: Entry point with dependency checking and startup information
- mcp_server.py: MCP protocol implementation, tool registration, and request routing
- dbtool.py: Database operations, SQL generation, and data management
- filetool.py: Vector database operations, file processing, and semantic search
Business Logic Classes:
- DatabaseManager: Handles async SQLite operations and database connections
- DatabaseTools: High-level database operations with natural language support
- OllamaClient: Manages AI model communication for SQL generation
- VectorDatabaseManager: Manages ChromaDB operations and document embeddings
- FileTools: High-level file operations and semantic search functionality
Troubleshooting
Common Issues
- Server won't start: Check if Ollama is running on port 1434
- No tools showing in Claude: Verify MCP config path and restart Claude Desktop
- SQL errors: Check table names and ensure proper natural language descriptions
- Ollama connection failed: Confirm Ollama model is installed and accessible
Debug Mode
Run with Python's verbose mode for detailed logs:
python -v main.py
License
This project is open source. See LICENSE file for details.
Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests if applicable
- Submit a pull request
Support
For issues and questions:
- Check the troubleshooting section
- Review Ollama and MCP documentation
- Open an issue on the repository
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.