JSON 필드 내의 데이터를 기반으로 MySQL 테이블을 어떻게 조인할 수 있나요?

Barbara Streisand
풀어 주다: 2024-10-30 15:04:03
원래의
435명이 탐색했습니다.

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 함수를 사용하여 사용자 그룹 ID가 사용자의 JSON 필드 내에 있는지 확인하는 작업이 포함됩니다. 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!