首頁 >資料庫 >mysql教程 >如何根據 JSON 欄位中的資料連接 MySQL 表?

如何根據 JSON 欄位中的資料連接 MySQL 表?

Barbara Streisand
Barbara Streisand原創
2024-10-30 15:04:03513瀏覽

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

使用MySQL JSON 欄位進行複雜資料表連線

問題:

問題:

範例場景:

考慮下表:

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
期望結果是一個查詢檢索以下資料:

解決方案:

<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 欄位中是否存在使用者群組ID

注意:

JSON_CONTAINS 函數中的$ 運算子表示JSON 文件的根。

以上是如何根據 JSON 欄位中的資料連接 MySQL 表?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn