まず、テーブル "payments" には以下のカラムが存在します:
- id: ユニークな識別子として使用される支払いID
- course_id: 支払いが関連付けられているコースのID
- user_id: 支払いを行ったユーザーのID
- score: コースのスコア
これらのテーブル間の関連性を分析する方法の一つは、外部キー制約を使用することです。具体的には、"payments" テーブルの "course_id" カラムを "courses" テーブルの主キーに関連付けることができます。これにより、コースと支払いの間に関連性が確立されます。
関連付けられたテーブルからデータを取得するためには、SQLクエリを使用します。以下に、いくつかの例を示します。
- 特定の支払いIDに関連するコース情報を取得するクエリ:
SELECT *
FROM payments
JOIN courses ON payments.course_id = courses.id
WHERE payments.id = <支払いID>;
- 特定のユーザーが受けた全てのコースとスコアを取得するクエリ:
SELECT courses.*, payments.score
FROM payments
JOIN courses ON payments.course_id = courses.id
WHERE payments.user_id = <ユーザーID>;
- 特定のコースの平均スコアを計算するクエリ:
SELECT AVG(score)
FROM payments
WHERE course_id = <コースID>;
これらのクエリは、テーブル間の関連性を活用し、必要なデータを取得するための基本的な例です。実際の使用ケースに応じて、クエリをカスタマイズすることができます。
データベースのテーブル間の関連性を理解し、適切なクエリを使用することで、有益な情報を抽出し、データ分析やレポート作成に役立てることができます。