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 중국어 웹사이트의 기타 관련 기사를 참조하세요!