**LIMIT 및 오프셋을 사용한 MySQL DELETE로 인해 오류가 발생하는 이유는 무엇입니까?**

Susan Sarandon
풀어 주다: 2024-10-25 11:21:02
원래의
210명이 탐색했습니다.

**Why does MySQL DELETE with LIMIT and Offset Cause an Error?**

LIMIT와 함께 MySQL DELETE 문을 사용할 때 오류가 발생했습니다.

문제:

LIMIT 절이 포함된 MySQL DELETE 문을 사용하여 테이블에서 행을 삭제하면 LIMIT 절의 오프셋 값에서 오류가 발생합니다. 다음 쿼리는 문제를 예시합니다.

DELETE FROM `chat_messages` ORDER BY `timestamp` DESC LIMIT 20, 50;
로그인 후 복사

오프셋 값(50)에서 수신된 오류 메시지는 다음과 같습니다.

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ' 50' at line 1
로그인 후 복사

해결책:

이 오류는 MySQL이 DELETE 문의 LIMIT 절에 오프셋 지정을 허용하지 않기 때문에 발생합니다. 따라서 원하는 결과를 얻으려면 대체 접근 방식을 사용해야 합니다.

범위를 기준으로 테이블에서 특정 행을 삭제하려면 기본 DELETE 쿼리 내에 중첩된 하위 쿼리를 사용할 수 있습니다. 다음 수정된 쿼리는 이 기술을 보여줍니다.

<code class="sql">DELETE FROM `chat_messages` 
WHERE `id` IN (
    SELECT `id` FROM (
        SELECT `id` FROM `chat_messages`
        ORDER BY `timestamp` DESC
        LIMIT 20, 50
    ) AS `x`
)</code>
로그인 후 복사

이 쿼리에서 IN 절 내의 하위 쿼리는 지정된 범위를 기반으로 삭제할 행의 ID를 검색합니다. 테이블에 id라는 기본 키 열이 있다고 가정하면 이를 사용하여 각 행을 고유하게 식별할 수 있습니다.

참고: MySQL에서 선택할 수 없는 문제를 방지하려면 이중 중첩을 구현하는 것이 중요합니다. 현재 수정된 테이블입니다.

위 내용은 **LIMIT 및 오프셋을 사용한 MySQL DELETE로 인해 오류가 발생하는 이유는 무엇입니까?**의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!