DB & Calculator MCP Server

DB & Calculator MCP Server

A Model Context Protocol server providing tools for SQLite database operations (query, add, update, delete users) and mathematical calculations including basic arithmetic, expression evaluation, and statistical analysis.

Category
Visit Server

README

MCP Example Server

This is a Model Context Protocol (MCP) server that provides two main categories of tools:

  1. Database Tools - For interacting with a SQLite database
  2. Calculator Tools - For performing mathematical calculations

Features

Database Tools

  • query_database - Execute custom SQL queries
  • get_all_users - Retrieve all users with optional limit
  • get_user_by_id - Get a specific user by ID
  • add_user - Add a new user to the database
  • update_user - Update an existing user
  • delete_user - Delete a user from the database

Calculator Tools

  • calculate - Perform basic mathematical operations (add, subtract, multiply, divide, power, sqrt, sin, cos, tan, log, abs, round, floor, ceil)
  • calculate_expression - Evaluate mathematical expressions
  • calculate_stats - Calculate statistical measures (mean, median, variance, standard deviation, etc.)

Installation

  1. Install dependencies:
npm install
  1. The database will be automatically created when you first run the server.

Usage

Starting the Server

npm start

Or for development with auto-restart:

npm run dev

Database Schema

The server creates a SQLite database with the following schema:

CREATE TABLE users (
  id INTEGER PRIMARY KEY AUTOINCREMENT,
  name TEXT NOT NULL,
  email TEXT UNIQUE NOT NULL,
  age INTEGER,
  created_at DATETIME DEFAULT CURRENT_TIMESTAMP
);

Sample data is automatically inserted when the database is first created.

Tool Examples

Database Operations

  1. Get all users:
{
  "name": "get_all_users",
  "arguments": {}
}
  1. Get user by ID:
{
  "name": "get_user_by_id",
  "arguments": {
    "id": 1
  }
}
  1. Add a new user:
{
  "name": "add_user",
  "arguments": {
    "name": "John Doe",
    "email": "john@example.com",
    "age": 30
  }
}
  1. Execute custom query:
{
  "name": "query_database",
  "arguments": {
    "query": "SELECT * FROM users WHERE age > 25"
  }
}

Calculator Operations

  1. Basic calculation:
{
  "name": "calculate",
  "arguments": {
    "operation": "add",
    "numbers": [5, 3]
  }
}
  1. Evaluate expression:
{
  "name": "calculate_expression",
  "arguments": {
    "expression": "2 + 3 * 4"
  }
}
  1. Statistical analysis:
{
  "name": "calculate_stats",
  "arguments": {
    "numbers": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
  }
}

Available Calculator Operations

  • add - Addition
  • subtract - Subtraction
  • multiply - Multiplication
  • divide - Division (with zero check)
  • power - Exponentiation
  • sqrt - Square root
  • sin - Sine function
  • cos - Cosine function
  • tan - Tangent function
  • log - Natural logarithm
  • abs - Absolute value
  • round - Round to nearest integer
  • floor - Floor function
  • ceil - Ceiling function

Project Structure

├── package.json
├── README.md
├── src/
│   ├── server.js      # Main MCP server
│   ├── database.js    # Database operations
│   └── calculator.js  # Calculator operations
└── data/
    └── example.db     # SQLite database (created automatically)

Error Handling

The server includes comprehensive error handling for:

  • Invalid SQL queries
  • Database connection issues
  • Mathematical operation errors (division by zero, invalid inputs)
  • Missing required parameters
  • Unknown tool names

Development

To modify or extend the server:

  1. Add new tools in the setupTools() method in server.js
  2. Implement corresponding handler methods
  3. Update the tools list in the tools/list handler
  4. Add any necessary database operations in database.js
  5. Add calculator functions in calculator.js

Dependencies

  • @modelcontextprotocol/sdk - MCP SDK for Node.js
  • sqlite3 - SQLite database driver
  • express - Web framework (for potential future HTTP transport)

License

MIT

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured