SQLite MCP Server

SQLite MCP Server

A universal SQLite database management tool that enables SQL query execution through MCP protocol. Supports SELECT/INSERT/UPDATE/DELETE/CREATE operations with built-in SQL injection protection across stdio, SSE, and streamable-http communication modes.

Category
访问服务器

README

SQLite MCP Server

通用SQLite数据库管理工具,通过MCP协议提供SQL执行能力。

功能特性

  • 执行任意合法的SQL查询
  • 支持SELECT/INSERT/UPDATE/DELETE/CREATE等操作
  • 内置SQL注入防护
  • 支持stdio、SSE和streamable-http三种通信模式
  • 可配置的IP和端口

快速开始

安装依赖

pip install -r requirements.txt

SQLite3 是Python内置模块,无需单独安装。

启动服务器

# 默认配置
python app/main.py

# 自定义配置
# stdio模式
python app/main.py --server_type stdio

# sse模式
python app/main.py --server_type sse --host 0.0.0.0 --port 8000

# streamable-http模式 (注意使用短横线)
python app/main.py --server_type streamable-http --host 127.0.0.1 --port 8080

客户端调用示例

使用提供的客户端类

# 导入客户端类
from client import SQLiteMCPClient

# 创建客户端实例 (默认使用SSE模式)
client = SQLiteMCPClient(server_type="sse", host="localhost", port=8000)

# 创建表
result = client.execute_sql("""
CREATE TABLE IF NOT EXISTS users (
    id INTEGER PRIMARY KEY,
    name TEXT NOT NULL,
    email TEXT UNIQUE,
    age INTEGER
)
""")

# 插入数据 (使用参数化查询防止SQL注入)
result = client.execute_sql(
    "INSERT INTO users (name, email, age) VALUES (?, ?, ?)",
    ["张三", "zhangsan@example.com", 30]
)

# 查询数据
result = client.execute_sql("SELECT * FROM users")
print(result)

# 关闭客户端
client.close()

直接调用MCP工具

# 查询数据
execute_sql({
    "query": "SELECT * FROM table WHERE condition"
})

# 插入数据 (带参数)
execute_sql({
    "query": "INSERT INTO table (col1, col2) VALUES (?, ?)",
    "parameters": ["value1", "value2"]
})

# 创建表
execute_sql({
    "query": "CREATE TABLE IF NOT EXISTS table (id INTEGER PRIMARY KEY, name TEXT)"
})

配置与启动

启动参数

参数 默认值 描述
--server_type sse 服务器类型: stdio/sse/streamable-http
--host 0.0.0.0 监听地址
--port 8000 监听端口
--log_level INFO 日志级别: DEBUG/INFO/WARNING/ERROR

环境变量配置

环境变量 默认值 描述
MCP_HOST 0.0.0.0 监听地址
MCP_PORT 8000 监听端口
MCP_SERVER_TYPE sse 服务器类型 (sse/stdio/streamable-http)

数据库自动创建

服务启动时会自动在项目根目录创建demo.db数据库文件(如果不存在)

启动示例

# SSE模式 (默认)
python app/main.py --server_type sse --port 8000

# stdio模式
python app/main.py --server_type stdio

# streamable-http模式 (注意使用短横线)
python app/main.py --server_type streamable-http --port 8080

# 带调试日志
python app/main.py --log_level DEBUG

JSON配置示例

stdio模式配置

{
  "mcpServers": {
    "sqlite-mcp": {
      "command": "python",
      "args": ["app/main.py", "--server_type", "stdio"]
    }
  }
}

sse模式配置

{
  "mcpServers": {
    "sqlite-mcp": {
      "type": "sse",
      "url": "http://localhost:8000/sse",
      "port": 8000
    }
  }
}

streamable-http模式配置

{
  "mcpServers": {
    "sqlite-mcp": {
      "type": "streamableHttp",
      "url": "http://localhost:8000/mcp",
      "port": 8000,
      "headers": {
        "Content-Type": "application/json"
      }
    }
  }
}

项目结构

SQLite-MCP-Server/
├── app/                 # 主应用代码
│   ├── main.py          # 主入口
│   ├── config.py        # 配置管理
│   ├── database.py      # 数据库连接  
│   ├── models/          # 数据模型
│   │   ├── __init__.py
│   │   └── sql_utils.py # SQL工具类
│   └── tools/           # MCP工具
│       ├── __init__.py
│       └── crud.py      # SQL执行工具
├── client.py            # 客户端示例
├── README.md            # 项目文档
├── requirements.txt     # 依赖列表
└── demo.db              # 自动创建的SQLite数据库文件

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选