ANY_VALUE 함수 및 MySQL 호환성
MySQL 버전 5.6에는 MySQL 5.7에 도입된 ANY_VALUE 함수가 없습니다. 이는 최신 버전의 MySQL에서 ANY_VALUE 함수를 사용하지만 프로덕션 환경에서는 5.6으로 작업하는 개발자에게 어려운 과제입니다.
SQL 모드 및 호환성
MySQL의 ONLY_FULL_GROUP_BY 모드는 쿼리를 방지합니다. GROUP BY 절에 포함되지 않은 열을 검색하는 질문에 제시된 것과 같습니다. 이 모드를 끄면 MySQL 5.6에서 쿼리를 실행할 수 있습니다.
SET @mode := @@SESSION.sql_mode; SET SESSION sql_mode = ''; /* your query here */ SET SESSION sql_mode = @mode;
그러나 이 접근 방식은 불확실한 결과를 생성할 수 있으므로 권장되지 않습니다. ANY_VALUE 함수는 그룹에서 무작위로 선택된 값을 반환하므로 혼란과 지원 문제가 발생할 수 있습니다.
MySQL 5.6용 대체 쿼리
예측 가능한 결과를 얻으려면 수정을 고려하세요. 국가별 특정 이미지를 선택하는 쿼리입니다. 이미지 테이블에 자동 증가 ID 열이 포함된 경우 다음 쿼리를 사용할 수 있습니다.
SELECT c.id, c.name, i.* FROM countries c LEFT JOIN ( SELECT MIN(id) id, country_id FROM images GROUP BY country_id ) first ON c.id = first.country_id LEFT JOIN images i ON first.id = i.id
이 쿼리는 각 국가에 대해 하나의 이미지가 반환되도록 보장하여 보다 일관되고 안정적인 결과 집합을 제공합니다.
위 내용은 MySQL 5.6에서 ANY_VALUE() 함수와 동등한 기능을 어떻게 사용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!