WHERE 절을 사용하여 왼쪽 조인: 기본 및 역할별 설정 가져오기
애플리케이션 쿼리는 'settings' 테이블에서 기본 설정을 검색하고 'character_settings' 테이블(있는 경우)에서 문자별 설정을 캡처해야 합니다. 그러나 현재 쿼리는 역할 ID가 1인 설정만 반환하며 기본 설정은 누락되었습니다.
초기 쿼리는 WHERE 절을 사용하여 역할 ID가 존재하는 설정을 필터링하려고 시도합니다.
SELECT `settings`.*, `character_settings`.`value` FROM (`settings`) LEFT JOIN `character_settings` ON `character_settings`.`setting_id` = `settings`.`id` WHERE `character_settings`.`character_id` = '1'
그러나 이렇게 하면 왼쪽 조인이 일치하지 않는 행이 필터링되어 원하는 기본값이 제거됩니다.
해결책:
이 문제를 해결하려면 일치하는 역할 설정이 있는 조인 행에만 WHERE 절을 재배치하세요.
SELECT `settings`.*, `character_settings`.`value` FROM `settings` LEFT JOIN `character_settings` ON `character_settings`.`setting_id` = `settings`.`id` AND `character_settings`.`character_id` = '1'
이제 쿼리는 기본 설정과 역할별 설정(있는 경우)을 수집합니다. 기본값과 역할 값이 혼합된 출력 배열 구조는 다음과 같이 생성할 수 있습니다.
$result = array(); foreach ($result_set as $row) { $result[$row['key']] = $row['value']; }
위 내용은 Left Join을 사용하여 기본 및 문자별 설정을 효율적으로 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!