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

Barbara Streisand
リリース: 2024-10-28 04:41:02
オリジナル
266 人が閲覧しました

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 ステートメント内の行をフィルタリングすることです。

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

<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>
ログイン後にコピー

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

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

以上がMySQL DELETE ステートメントで LIMIT を使用して行範囲を削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!