使用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中文網其他相關文章!