Provides intent-based tools for querying and analyzing the Sakila sample database, including film search, customer management, rental operations, revenue analysis, and inventory tracking without exposing underlying database schema.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Sakila MCP Serversearch for action movies starring Tom Hanks"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Sakila MCP Server
MySQL(Sakilaデータベース)にアクセスするMCPサーバーのPython実装です。
概要
このプロジェクトは、Model Context Protocol (MCP) を使用して、LLM(Claude等)からSakilaデータベースに自然言語でアクセスできるようにします。
Intent-Based API設計を採用し、データベーススキーマを非公開としながら、ビジネス意図ベースの18種類のツールを提供します。
システム構成
設計思想
スキーマ非公開: テーブル構造、カラム名、FK関係は一切公開しない
ビジネス意図ベース: 「映画を検索する」「顧客詳細を取得する」などの意図に対応
セキュリティ重視: パラメータ化クエリ、入力検証、エラーメッセージ制御
提供ツール(18種類)
映画検索・情報系
ツール名 | 機能 | 主要パラメータ |
| 映画検索(タイトル、カテゴリ、レーティング、俳優名) | title, category, rating, actor_name, limit |
| 映画詳細取得(出演者・在庫情報含む) | title |
| カテゴリ一覧取得 | なし |
| 在庫・貸出状況確認 | title, store_id |
顧客管理系
ツール名 | 機能 | 主要パラメータ |
| 顧客検索 | name, email, store_id, active_only |
| 顧客詳細取得(住所・履歴サマリー含む) | customer_id or email |
レンタル業務系
ツール名 | 機能 | 主要パラメータ |
| レンタル履歴取得 | customer_id, status |
| 延滞一覧取得 | store_id, days_overdue |
分析・レポート系
ツール名 | 機能 | 主要パラメータ |
| 人気映画ランキング | period, category, store_id, limit |
| 売上サマリー | group_by, store_id, period |
| 店舗統計 | store_id |
| 俳優の出演作品一覧 | actor_name |
顧客分析系
ツール名 | 機能 | 主要パラメータ |
| 優良顧客ランキング | metric (rentals/spending), period, limit |
| 顧客セグメント分析 | なし(自動分類) |
| 顧客アクティビティ分析 | period |
在庫・商品分析系
ツール名 | 機能 | 主要パラメータ |
| 在庫回転率分析 | store_id, category |
| カテゴリ別パフォーマンス | period, store_id |
| 低稼働作品一覧 | days_not_rented, store_id |
セットアップ
1. リポジトリのクローン
2. 環境変数の設定
3. MySQL の起動
初回起動時、Sakilaデータベースが自動的にインポートされます(約1-2分)。
4. 依存関係のインストール
5. サーバーの起動(動作確認)
Claude Desktop への接続
~/Library/Application Support/Claude/claude_desktop_config.json(macOS)または適切な設定ファイルに以下を追加:
使用例
Claude Desktopで以下のような質問ができます。
映画検索
「アクション映画を検索して」
「PG-13の映画を5本教えて」
「Tom Hanksが出演している映画は?」
「映画'ACADEMY DINOSAUR'の詳細を教えて」
顧客情報
「Smithという名前の顧客を検索して」
「顧客ID 1番の詳細情報を見せて」
「アクティブな顧客だけを検索して」
レンタル業務
「顧客ID 1番のレンタル履歴を見せて」
「延滞している顧客は誰?」
「店舗1の延滞状況を確認して」
分析・レポート
「今月の人気映画ランキングを教えて」
「カテゴリ別の売上サマリーを見せて」
「店舗ごとの統計を比較して」
「優良顧客TOP10は?」
在庫分析
「在庫回転率が低い映画は?」
「カテゴリ別のパフォーマンスを分析して」
「30日以上レンタルされていない映画を教えて」
開発
リント・フォーマット
テスト
DB接続情報
項目 | 値 |
Host | localhost |
Port | 3306 |
Database | sakila |
User | sakila_user |
Password | sakila_pass |
セキュリティ
実装済み対策
パラメータ化クエリ: すべてのユーザー入力は
%sプレースホルダー経由入力検証: 許可値リストによるバリデーション
rating: G, PG, PG-13, R, NC-17
store_id: 1, 2
period: all_time, last_month, last_week
等
数値制限: limitは最大50件
フィールド制限: 返却JSONは必要フィールドのみ
エラーメッセージ: SQLエラー詳細は非公開
ディレクトリ構成
ドキュメント
CLAUDE.md - 開発者向け詳細ガイド(アーキテクチャ、コーディング規約、テストパターン)
docs/SAKILA_DATABASE.md - Sakilaデータベース概要
docs/MCP_IMPLEMENTATION_PATTERNS.md - MCP実装パターンガイド
参考資料
ライセンス
MIT