FROM 句で更新するターゲット テーブル 'table_name' を指定できません - MySQL エラーの解決方法: FROM 句でターゲット テーブルを更新できません

PHPz
リリース: 2023-10-05 10:25:13
オリジナル
1393 人が閲覧しました

You can\'t specify target table \'table_name\' for update in FROM clause - 如何解决MySQL报错:无法在FROM子句中更新目标表

こんにちは、以下は 1500 ワード以内の記事です。タイトルは「FROM 句で更新するターゲット テーブル 'table_name' を指定できません - MySQL エラーを解決する方法: を更新できません」です。 FROM 句のターゲット テーブルには特定のコード例が必要です。


MySQL データベースの開発中に、次のエラー メッセージが表示されることがあります: FROM 句の表面で更新のターゲット テーブル 'table_name' を指定することはできません)。このエラーは通常、サブクエリで UPDATE ステートメントを使用する場合、特に更新する必要があるターゲット テーブルがサブクエリで参照されている場合に発生します。

この記事では、このエラーの原因を紹介し、解決策と具体的なコード例を示します。

まず、このエラーを再現する例を見てみましょう:

UPDATE table_name
SET column_name = value
WHERE column_name IN (SELECT column_name FROM table_name WHERE condition);
ログイン後にコピー

上記のコードでは、table_name という名前のテーブルを更新し、WHERE 条件としてサブクエリを使用しようとしています。ただし、MySQL では、FROM 句でターゲット テーブルを直接更新することはできません。

このエラーの理由は、MySQL が UPDATE ステートメントを実行する順序にあります。 MySQL の実行シーケンスは、まず FROM 句からデータを取得し、次に WHERE 条件に基づいてフィルタリングおよび更新操作を実行します。サブクエリ内で更新が必要なターゲットテーブルを参照するため、更新中にターゲットテーブルを参照できないため、競合が発生します。

この問題を解決するには、コードを変更する必要があります。以下にいくつかの一般的な解決策を示します。

解決策 1: INNER JOIN を使用する

UPDATE table_name
INNER JOIN (SELECT column_name FROM table_name WHERE condition) AS temp_table
ON table_name.column_name = temp_table.column_name
SET table_name.column_name = value;
ログイン後にコピー

上記のコードでは、ターゲット テーブルとサブクエリの結果セットを INNER JOIN で接続し、WHERE を渡します。フィルタリングする条件。このようにして、更新プロセス中にエラー メッセージを表示せずにサブクエリの結果を参照できます。

解決策 2: 一時テーブルを使用する

CREATE TEMPORARY TABLE temp_table
SELECT column_name FROM table_name WHERE condition;

UPDATE table_name
SET column_name = value
WHERE column_name IN (SELECT column_name FROM temp_table);
ログイン後にコピー

この解決策では、最初にサブクエリの結果セットを一時テーブルに保存し、次に一時テーブルを使用して更新操作を実行します。こうすることで、ターゲットテーブルを更新するときにそれ自体を参照する問題を回避できます。

解決策 3: サブクエリをフィールドとして使用する

UPDATE table_name
SET column_name = (
    SELECT column_name FROM table_name WHERE condition
)
WHERE column_name = value;
ログイン後にコピー

この解決策では、サブクエリをフィールド値として更新します。 UPDATE ステートメントのフィールドとしてサブクエリを使用すると、FROM 句でターゲット テーブルを直接更新する制限を回避できます。

要約すると、「MySQL の FROM 句では更新にターゲット テーブル 'table_name' を指定できません」というエラー メッセージが表示された場合、これは UPDATE ステートメントで更新中のターゲット テーブルを参照したことを意味します。この問題を解決するには、INNER JOIN、一時テーブル、またはサブクエリをフィールドとして使用して更新操作を実行できます。

上記の解決策とコード例が、この MySQL エラー問題の解決に役立つことを願っています。他にご質問がございましたら、引き続きお気軽にご質問ください。

以上がFROM 句で更新するターゲット テーブル 'table_name' を指定できません - MySQL エラーの解決方法: FROM 句でターゲット テーブルを更新できませんの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート