GROUP BY: NULL 값 무시
데이터베이스 관리에서 GROUP BY 함수는 특정 열의 유사한 값을 기준으로 행을 그룹화하는 역할을 합니다. 또는 열. 그러나 NULL 값을 고유한 그룹으로 처리하므로 NULL 필드가 발견되면 의도하지 않은 결과가 발생할 가능성이 있습니다.
다음 쿼리를 고려하십시오.
SELECT `table1`.*, GROUP_CONCAT(id SEPARATOR ',') AS `children_ids` FROM `table1` WHERE (enabled = 1) GROUP BY `ancestor`
table1에 5개의 행이 있다고 가정합니다. 조상 필드가 NULL로 설정된 경우 쿼리는 행 하나만 반환하지만 원하는 결과는 5개 행을 모두 검색하는 것입니다.
이를 극복하려면 문제에서는 고유 식별자를 도입하여 NULL 값을 구별하는 전략을 사용할 수 있습니다. 예는 다음과 같습니다.
SELECT `table1`.*, IFNULL(ancestor,UUID()) as unq_ancestor GROUP_CONCAT(id SEPARATOR ',') AS `children_ids` FROM `table1` WHERE (enabled = 1) GROUP BY unq_ancestor
이 수정된 쿼리에서는 IFNULL() 함수를 사용하여 상위 열의 NULL 값에 UUID(Universally Unique Identifiers)를 할당합니다. 이를 통해 각 행에 대한 고유 식별자를 생성하여 NULL 값을 효과적으로 구분하고 그룹화할 수 있습니다. 이렇게 하면 상위 필드가 NULL인지 여부에 관계없이 모든 행이 결과 집합에 반환됩니다.
위 내용은 MySQL의 GROUP BY 절에서 NULL 값이 예기치 않은 그룹을 생성하는 것을 방지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!