복잡한 테이블 조인에 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!