Model Context Protocol server that exposes sql-sop's SQL linter to LLMs (Claude, Cursor, ChatGPT, Continue).
Project description
sql-sop-mcp
Model Context Protocol server that wires sql-sop into any MCP-aware LLM client. Lets Claude Desktop, Cursor, ChatGPT desktop, Continue, and similar tools call sql-sop's linter as a callable tool from inside a chat.
The point: when an LLM generates SQL for you, it can lint that SQL itself before suggesting it. Or you can say "lint this query", paste the SQL, and the model uses the tool rather than guessing.
What it exposes
Two tools, both stdio-transport:
| Tool | What it does |
|---|---|
lint_sql(sql, severity?, disable?) |
Run sql-sop against a SQL string. Returns {passed, summary, findings[]}. Each finding has rule_id, severity, line, message, suggestion. |
list_rules() |
Return the full rule catalogue (38 rules in sql-sop v0.6.1). |
Backed by sql-sop — a fast rule-based SQL linter with 33 SQL rules (including 5 T-SQL specific ones) and 5 Python source rules for SQL injection on cursor.execute() / sqlalchemy.text(). There's a browser playground if you want to feel out the rules before wiring this up.
Install
pip install sql-sop-mcp
Or with pipx if you want the CLI on PATH without polluting your project's venv:
pipx install sql-sop-mcp
Wire it into your LLM client
Claude Desktop
Edit ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"sql-sop": {
"command": "sql-sop-mcp"
}
}
}
Restart Claude Desktop. New chats will see two tools: lint_sql and list_rules.
Cursor
Edit ~/.cursor/mcp.json:
{
"mcpServers": {
"sql-sop": {
"command": "sql-sop-mcp"
}
}
}
Continue (VS Code / JetBrains plugin)
Add to ~/.continue/config.json:
{
"mcpServers": [
{
"name": "sql-sop",
"command": "sql-sop-mcp"
}
]
}
Generic stdio-MCP client
Anything that speaks MCP over stdio will work. Run sql-sop-mcp as a subprocess and talk to it on stdin/stdout.
What a typical interaction looks like
You: "Write me a query to remove inactive users older than a year and lint it before suggesting."
The model calls lint_sql against its draft, gets back something like:
{
"passed": false,
"summary": "1 error, 1 warning in 1 statement",
"findings": [
{
"rule_id": "E001",
"severity": "error",
"line": 1,
"message": "DELETE without WHERE clause -- this will delete all rows",
"suggestion": "Add a WHERE clause to limit affected rows"
},
{
"rule_id": "W003",
"severity": "warning",
"line": 1,
"message": "Function on column in WHERE -- kills index usage",
"suggestion": "Move the function to the value side: WHERE date >= '2024-01-01'"
}
]
}
It then revises the query and lints again before showing it to you.
When to use disable
If the model is sure a rule is a false positive in context (e.g. a one-off admin script where SELECT * is genuinely fine), it can pass disable: ["W001"]. Treat this as the model's reasoning surface — read the suggested rationale, not just the final SQL.
Roadmap (open to PRs)
lint_file(path)— lint a file the LLM has access to via filesystem MCPexplain_rule(rule_id)— return the rule's full documentation, examples of pass/fail SQLlint_python_file(path)— wrap the Python-source scanner so the LLM can audit.pyfiles forcursor.execute(f"...")SQL injectionsuggest_index(sql, schema)— emit candidate covering-index DDL based on the query
Related
- sql-sop — the linter this server wraps. CLI, pre-commit hook, GitHub Action, browser playground
- pr-sop — sister tool for PR governance
- Model Context Protocol — the spec
- FastMCP — the Python framework this server is built on
License
MIT. See LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file sql_sop_mcp-0.1.1.tar.gz.
File metadata
- Download URL: sql_sop_mcp-0.1.1.tar.gz
- Upload date:
- Size: 6.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8381a7d767e912e1ac96c215fd4ac633b6339e242d9f0327f9f5c27633dbdced
|
|
| MD5 |
96dc3e967a8c41d9871133f185dd624e
|
|
| BLAKE2b-256 |
075fd57cda755d01e17fa11ffe816922dbc7767fd237f949c929c09435e9e81a
|
Provenance
The following attestation bundles were made for sql_sop_mcp-0.1.1.tar.gz:
Publisher:
release.yml on Pawansingh3889/sql-sop-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
sql_sop_mcp-0.1.1.tar.gz -
Subject digest:
8381a7d767e912e1ac96c215fd4ac633b6339e242d9f0327f9f5c27633dbdced - Sigstore transparency entry: 1390035169
- Sigstore integration time:
-
Permalink:
Pawansingh3889/sql-sop-mcp@e9fa41e054f4bc6871d837ee1184844bc662b5a8 -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/Pawansingh3889
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@e9fa41e054f4bc6871d837ee1184844bc662b5a8 -
Trigger Event:
push
-
Statement type:
File details
Details for the file sql_sop_mcp-0.1.1-py3-none-any.whl.
File metadata
- Download URL: sql_sop_mcp-0.1.1-py3-none-any.whl
- Upload date:
- Size: 6.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6d11c741bb77574e75011b3b3f33223f75249824848000ed082254b6a2281ed6
|
|
| MD5 |
a4f4529b9c443ee3684d0754082311c0
|
|
| BLAKE2b-256 |
cdc92353cd28f47e766d4a553aa1f16dbdffe7d46a323b32ed5a0a8762c8156f
|
Provenance
The following attestation bundles were made for sql_sop_mcp-0.1.1-py3-none-any.whl:
Publisher:
release.yml on Pawansingh3889/sql-sop-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
sql_sop_mcp-0.1.1-py3-none-any.whl -
Subject digest:
6d11c741bb77574e75011b3b3f33223f75249824848000ed082254b6a2281ed6 - Sigstore transparency entry: 1390035245
- Sigstore integration time:
-
Permalink:
Pawansingh3889/sql-sop-mcp@e9fa41e054f4bc6871d837ee1184844bc662b5a8 -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/Pawansingh3889
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@e9fa41e054f4bc6871d837ee1184844bc662b5a8 -
Trigger Event:
push
-
Statement type: