ホームページ > データベース > mysql チュートリアル > JSON フィールド内のデータに基づいて MySQL テーブルを結合するにはどうすればよいでしょうか?

JSON フィールド内のデータに基づいて MySQL テーブルを結合するにはどうすればよいでしょうか?

Barbara Streisand
リリース: 2024-10-30 15:04:03
オリジナル
553 人が閲覧しました

How can you join MySQL tables based on data within a JSON field?

複雑なテーブル結合に MySQL JSON フィールドを使用する

問題:

MySQL データベース内スキーマでは、JSON フィールドに ID のリストが保存されます。目標は、この JSON フィールドで操作を実行し、その結果を SQL クエリで使用してユーザー テーブルとユーザー グループ テーブルを結合することです。

シナリオ例:

次のテーブルについて考えてみましょう:

CREATE TABLE user (
    user_id INT,
    user_name VARCHAR(50),
    user_groups JSON
);

CREATE TABLE user_group (
    user_group_id INT,
    group_name VARCHAR(50)
);
ログイン後にコピー

次のデータ:

INSERT INTO user_group (user_group_id, group_name) VALUES (1, 'Group A');
INSERT INTO user_group (user_group_id, group_name) VALUES (2, 'Group B');
INSERT INTO user_group (user_group_id, group_name) VALUES (3, 'Group C');

INSERT INTO user (user_id, user_name, user_groups) VALUES (101, 'John', '[1,3]');
ログイン後にコピー

望ましい結果:

望ましい結果は、次のクエリです。次のデータを取得します:

user_id | user_name | user_group_id | group_name|
-------------------------------------------------
101     | John      | 1             | Group A
101     | John      | 3             | Group C
ログイン後にコピー

解決策:

この解決策には、JSON_CONTAINS 関数を使用して、ユーザーの JSON フィールド内にユーザー グループ ID が存在するかどうかを確認することが含まれます。 table.

<code class="sql">SELECT 
       u.user_id, 
       u.user_name, 
       g.user_group_id,
       g.group_name
   FROM user u
   LEFT JOIN user_group g on JSON_CONTAINS(u.user_groups, CAST(g.user_group_id as JSON), '$')</code>
ログイン後にコピー

注:

JSON_CONTAINS 関数の $ 演算子は、JSON ドキュメントのルートを表します。

以上がJSON フィールド内のデータに基づいて MySQL テーブルを結合するにはどうすればよいでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート