>데이터 베이스 >MySQL 튜토리얼 >JOIN을 사용하여 MySQL의 'LIMIT & IN/ALL/ANY/SOME 하위 쿼리' 오류를 수정하는 방법은 무엇입니까?

JOIN을 사용하여 MySQL의 'LIMIT & IN/ALL/ANY/SOME 하위 쿼리' 오류를 수정하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-13 10:08:18875검색

How to Fix MySQL's

MySQL 중첩 쿼리 오류: 'LIMIT & IN/ALL/ANY/SOME 하위 쿼리'는 지원되지 않습니다

이 오류는 MySQL의 IN 절 내에 LIMIT 절이 있는 하위 쿼리. 이 문제를 해결하기 위한 대체 접근 방식은 JOIN:

원본 코드:

$Last_Video         = $db->fetch_all('
SELECT VID, thumb
FROM video
WHERE VID IN (
    SELECT VID
    FROM video
    WHERE title LIKE "%'.$Channel['name'].'%"
    ORDER BY viewtime DESC
    LIMIT 5)
ORDER BY RAND()
LIMIT 1
');

리팩터링된 코드를 활용하는 것입니다. JOIN:

SELECT v.VID, v.thumb
FROM video AS v
INNER JOIN
     (SELECT VID
     FROM video
     WHERE title LIKE "%'.$Channel['name'].'%"
     ORDER BY viewtime DESC
     LIMIT 5) as v2
  ON v.VID = v2.VID
ORDER BY RAND()
LIMIT 1

설명:

JOIN 작업은 공통 VID 열을 기반으로 두 테이블(비디오 및 v2)을 연결합니다. 이렇게 하면 현재 MySQL 버전에서 지원되지 않는 IN 절 내에 LIMIT 절이 있는 중첩 쿼리가 필요하지 않습니다.

JOIN의 이점:

  • 데이터베이스 쿼리 수를 줄여 성능을 향상했습니다.
  • 더 간단하고 읽기 쉬운 쿼리 구조.
  • 여러 테이블과 조건을 사용하여 더욱 복잡한 쿼리 시나리오를 지원합니다.

위 내용은 JOIN을 사용하여 MySQL의 'LIMIT & IN/ALL/ANY/SOME 하위 쿼리' 오류를 수정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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