- Explore MCP Servers
- mcp-chinookdb-server
Mcp Chinookdb Server
What is Mcp Chinookdb Server
mcp-chinookdb-server is an MCP (Model Context Protocol) server designed to provide access to the Chinook SQLite database, allowing LLMs and other MCP-compatible clients to query the database using a standardized protocol.
Use cases
Use cases include querying the Chinook database for information about artists, albums, and tracks, performing data analysis, and developing applications that require database interactions.
How to use
To use mcp-chinookdb-server, clone the repository, install the required Python dependencies, and run the server. You can then interact with the server using the provided Agno test client for querying the database.
Key features
Key features include automatic database download, resource endpoints for schema retrieval, a SQL query tool for executing read-only queries, prompt templates for common tasks, safe SQL identifier escaping, and integration with an Agno agent client.
Where to use
mcp-chinookdb-server can be used in data analysis, application development, and educational environments where interaction with a sample database is required for testing or learning purposes.
Clients Supporting MCP
The following are the main client software that supports the Model Context Protocol. Click the link to visit the official website for more information.
Overview
What is Mcp Chinookdb Server
mcp-chinookdb-server is an MCP (Model Context Protocol) server designed to provide access to the Chinook SQLite database, allowing LLMs and other MCP-compatible clients to query the database using a standardized protocol.
Use cases
Use cases include querying the Chinook database for information about artists, albums, and tracks, performing data analysis, and developing applications that require database interactions.
How to use
To use mcp-chinookdb-server, clone the repository, install the required Python dependencies, and run the server. You can then interact with the server using the provided Agno test client for querying the database.
Key features
Key features include automatic database download, resource endpoints for schema retrieval, a SQL query tool for executing read-only queries, prompt templates for common tasks, safe SQL identifier escaping, and integration with an Agno agent client.
Where to use
mcp-chinookdb-server can be used in data analysis, application development, and educational environments where interaction with a sample database is required for testing or learning purposes.
Clients Supporting MCP
The following are the main client software that supports the Model Context Protocol. Click the link to visit the official website for more information.
Content
mcp-chinookdb-server
Example MCP Server to provide LLM MCP access to the example sqlite3 Chinook database
Overview
This project provides an MCP (Model Context Protocol) server for the Chinook SQLite database and a sample Agno agent client for interactive querying. It enables LLMs and other MCP-compatible clients to safely explore and query the Chinook database using a standardized protocol.
Key Features
- Automatic Database Download:
- Downloads and extracts the Chinook SQLite database if not present.
- Resource Endpoints:
schema://chinook/tables
: Returns the schema for all tables in the database.schema://chinook/table/{table_name}
: Returns the schema for a specific table.
- SQL Query Tool:
run_sql_query
: Allows execution of read-only (SELECT) SQL queries. Only SELECT statements are permitted for safety.
- Prompt Templates:
- Provides prompt templates for common tasks, such as listing tables, showing table schemas, counting rows, and querying top artists.
- Safe SQL Identifier Escaping:
- Includes a local function to safely escape SQL identifiers for SQLite.
- Agno Agent Integration:
- Includes a sample client (
agno_test_client.py
) that demonstrates how to connect to the MCP server and interact with it using an LLM agent.
- Includes a sample client (
How to Get Started
1. Installation
- Clone the repository:
curl -LsSf https://astral.sh/uv/install.sh | sh git clone <your-repo-url> cd mcp-chinookdb-server
- Install Python dependencies using uv:
Ensure you have Python 3.8+ installed and uv available in your environment.uv sync
2. Running the MCP Server
- Start the server:
The server will automatically download the Chinook database if needed and start listening for MCP requests (default: stdio transport).uv run chinook_mcp_server.py
3. Using the Agno Test Client
-
Start the interactive client:
uv run agno_test_client.py
This will launch a REPL where you can type natural language queries about the Chinook database. The client will start the MCP server (if not already running) and use an LLM (e.g., OpenAI GPT-4) to interpret your queries and interact with the database via MCP tools.
-
Example queries:
List all tables.
Show the schema for the Album table.
How many tracks are there in the database?
Who are the top 5 artists by number of tracks?
-
To exit: Type
q
,quit
, orexit
at the prompt.
How the Programs Work
chinook_mcp_server.py
- Implements an MCP server that exposes the Chinook database via resource endpoints, tools, and prompt templates.
- Handles automatic download and extraction of the database.
- Provides safe, read-only access to schema and data.
- Designed to be used by LLMs or any MCP-compatible client.
agno_test_client.py
- Demonstrates how to connect to the MCP server using the Agno agent framework.
- Starts the MCP server as a subprocess (using
uv run chinook_mcp_server.py
for fast startup). - Uses an LLM (e.g., OpenAI GPT-4) to interpret user queries and call MCP tools/resources.
- Provides a simple REPL for interactive exploration.
Security Notes
- Only SELECT queries are allowed via the
run_sql_query
tool. - SQL identifiers are safely escaped to prevent injection.
Customization
- You can add more MCP resources, tools, or prompts by following the patterns in
chinook_mcp_server.py
. - The client can be extended to use different LLMs or provide more advanced conversational features.
References
Chinook Database Overview
The Chinook SQLite database is a sample database that models a digital music store, similar to iTunes. It is widely used for SQL learning and demonstrations. The schema is designed to represent the core entities and relationships found in an online music store, including customers, employees, artists, albums, tracks, invoices, and more.
Concept Overview
- Artists release albums.
- Albums contain multiple tracks (songs or audio files).
- Tracks are categorized by genre and media type.
- Customers purchase tracks via invoices.
- Employees represent staff, including sales support.
- Invoice lines detail each track purchased in an invoice.
- Playlists allow grouping of tracks for listening.
Main Tables and Columns
-
Artist
ArtistId
(INTEGER, PK): Unique artist identifierName
(NVARCHAR): Artist name
-
Album
AlbumId
(INTEGER, PK): Unique album identifierTitle
(NVARCHAR): Album titleArtistId
(INTEGER, FK): Reference to the artist
-
Track
TrackId
(INTEGER, PK): Unique track identifierName
(NVARCHAR): Track nameAlbumId
(INTEGER, FK): Reference to the albumMediaTypeId
(INTEGER, FK): Reference to the media typeGenreId
(INTEGER, FK): Reference to the genreComposer
(NVARCHAR): Composer nameMilliseconds
(INTEGER): Track lengthBytes
(INTEGER): File sizeUnitPrice
(NUMERIC): Price per track
-
Genre
GenreId
(INTEGER, PK): Unique genre identifierName
(NVARCHAR): Genre name
-
MediaType
MediaTypeId
(INTEGER, PK): Unique media type identifierName
(NVARCHAR): Media type name (e.g., MPEG audio, AAC audio)
-
Customer
CustomerId
(INTEGER, PK): Unique customer identifierFirstName
,LastName
(NVARCHAR): Customer nameCompany
,Address
,City
,State
,Country
,PostalCode
(NVARCHAR): Contact infoPhone
,Fax
,Email
(NVARCHAR): Contact infoSupportRepId
(INTEGER, FK): Employee assigned to the customer
-
Employee
EmployeeId
(INTEGER, PK): Unique employee identifierLastName
,FirstName
(NVARCHAR): Employee nameTitle
(NVARCHAR): Job titleReportsTo
(INTEGER, FK): ManagerBirthDate
,HireDate
(DATETIME): DatesAddress
,City
,State
,Country
,PostalCode
,Phone
,Fax
,Email
(NVARCHAR): Contact info
-
Invoice
InvoiceId
(INTEGER, PK): Unique invoice identifierCustomerId
(INTEGER, FK): Customer making the purchaseInvoiceDate
(DATETIME): Date of invoiceBillingAddress
,BillingCity
,BillingState
,BillingCountry
,BillingPostalCode
(NVARCHAR): Billing infoTotal
(NUMERIC): Total amount
-
InvoiceLine
InvoiceLineId
(INTEGER, PK): Unique line item identifierInvoiceId
(INTEGER, FK): Reference to invoiceTrackId
(INTEGER, FK): Reference to trackUnitPrice
(NUMERIC): Price per trackQuantity
(INTEGER): Number of tracks purchased
-
Playlist
PlaylistId
(INTEGER, PK): Unique playlist identifierName
(NVARCHAR): Playlist name
-
PlaylistTrack
PlaylistId
(INTEGER, FK): Reference to playlistTrackId
(INTEGER, FK): Reference to track
This schema enables a wide range of queries and analytics, such as finding top artists, most popular genres, customer purchase history, and more.
Dev Tools Supporting MCP
The following are the main code editors that support the Model Context Protocol. Click the link to visit the official website for more information.