>데이터 베이스 >MySQL 튜토리얼 >Left Join을 사용하여 기본 및 문자별 설정을 효율적으로 검색하려면 어떻게 해야 합니까?

Left Join을 사용하여 기본 및 문자별 설정을 효율적으로 검색하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-22 07:56:101025검색

How Can I Efficiently Retrieve Default and Character-Specific Settings Using a Left Join?

WHERE 절을 사용하여 왼쪽 조인: 기본 및 역할별 설정 가져오기

애플리케이션 쿼리는 'settings' 테이블에서 기본 설정을 검색하고 'character_settings' 테이블(있는 경우)에서 문자별 설정을 캡처해야 합니다. 그러나 현재 쿼리는 역할 ID가 1인 설정만 반환하며 기본 설정은 누락되었습니다.

초기 쿼리는 WHERE 절을 사용하여 역할 ID가 존재하는 설정을 필터링하려고 시도합니다.

<code class="language-sql">SELECT `settings`.*, `character_settings`.`value`
FROM (`settings`)
LEFT JOIN `character_settings` 
ON `character_settings`.`setting_id` = `settings`.`id`
WHERE `character_settings`.`character_id` = '1'</code>

그러나 이렇게 하면 왼쪽 조인이 일치하지 않는 행이 필터링되어 원하는 기본값이 제거됩니다.

해결책:

이 문제를 해결하려면 일치하는 역할 설정이 있는 조인 행에만 WHERE 절을 재배치하세요.

<code class="language-sql">SELECT `settings`.*, `character_settings`.`value`
FROM `settings`
LEFT JOIN `character_settings` 
ON `character_settings`.`setting_id` = `settings`.`id`
AND `character_settings`.`character_id` = '1'</code>

이제 쿼리는 기본 설정과 역할별 설정(있는 경우)을 수집합니다. 기본값과 역할 값이 혼합된 출력 배열 구조는 다음과 같이 생성할 수 있습니다.

<code class="language-php">$result = array();
foreach ($result_set as $row) {
    $result[$row['key']] = $row['value'];
}</code>

위 내용은 Left Join을 사용하여 기본 및 문자별 설정을 효율적으로 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.