「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > MySQL DELETE ステートメントで LIMIT を使用して行範囲を削除するにはどうすればよいですか?

MySQL DELETE ステートメントで LIMIT を使用して行範囲を削除するにはどうすればよいですか?

2024 年 11 月 9 日に公開
ブラウズ:205

How to Delete a Range of Rows Using LIMIT in MySQL DELETE Statement?

LIMIT を使用した MySQL DELETE ステートメントの構文の修正

LIMIT を使用した DELETE ステートメントを使用して MySQL テーブルから行の範囲を削除しようとすると、 LIMIT 句を使用する場合、構文が間違っているとエラーが発生する可能性があります。このエラーは通常、制限の指定に使用される構文に問題があることを示します。

提供されたクエリの問題は、DELETE ステートメントの LIMIT 句でオフセットを指定できないことです。 DELETE ステートメントで LIMIT 句を使用する構文は、オフセットまたは開始点を指定せずに LIMIT です。

この問題を解決するには、削除する行を指定するようにクエリを書き直す必要があります。より正確には。これを行う 1 つの方法は、IN 句を使用して削除する行の ID を選択し、それらの ID を使用して DELETE ステートメント内の行をフィルター処理することです。

書き換え方法の例を次に示します。クエリ:

DELETE FROM `chat_messages` 
WHERE `id` IN (
    SELECT `id` FROM (
        SELECT `id` FROM `chat_messages`
        ORDER BY `timestamp` DESC
        LIMIT 20, 50
    ) AS `x`
)

このクエリでは、最初にサブクエリを使用して、削除する行の ID を選択します。次に、メインの DELETE ステートメントで IN 句を使用して、それらの ID に基づいて行をフィルター処理し、その結果、必要な範囲の行が削除されます。

調整が必要な場合があることに注意してください。テーブルの特定の構造と望ましい動作に基づいたクエリ。

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3