ホームページ > データベース > mysql チュートリアル > MySQL がストアドファンクションとトリガーでのテーブル変更をブロックするのはなぜですか?

MySQL がストアドファンクションとトリガーでのテーブル変更をブロックするのはなぜですか?

Barbara Streisand
リリース: 2024-12-07 13:16:18
オリジナル
313 人が閲覧しました

Why Does MySQL Block Table Modification in Stored Functions and Triggers?

MySQL ストアド関数/トリガー エラー: テーブル変更がブロックされました

MySQL でストアド関数またはトリガーを実行すると、次のエラーが発生する場合があります:

Error: Can't update table 'brandnames' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.
ログイン後にコピー

このエラーは、デッドロックの可能性があるため禁止されているストアド関数またはトリガー内からテーブルを更新しようとすると発生します。

次のような INSERT トリガーは、

CREATE TRIGGER `capital` AFTER INSERT ON `brandnames`
FOR EACH ROW UPDATE brandnames
SET bname = CONCAT( UCASE( LEFT( bname, 1 ) ) , LCASE( SUBSTRING( bname, 2 ) ) )
ログイン後にコピー

INSERT 操作がまだアクティブである間に、ブランド名テーブルの更新を試みます。 MySQL は、データの整合性を維持し、潜在的なエラーを回避するために、これを防止します。

この問題を解決するには、次の方法の使用を検討してください:

  • 新しい値へのアクセス: NEW を使用します。 .fieldname を使用して、INSERT 操作中に設定された値にアクセスします。これにより、テーブルに影響を与えることなく派生値を変更できます。
  • Before トリガーの使用: 可能であれば、テーブル変更ロジックを BEFORE INSERT トリガーに移動します。これにより、INSERT が完了する前に派生値を設定でき、エラーを回避できます。

たとえば、次のトリガーは、full_name 列の値に基づいて small_name 列を更新します。

CREATE TRIGGER `capital` BEFORE INSERT ON `brandnames`
FOR EACH ROW BEGIN
  SET NEW.small_name = CONCAT(UCASE(LEFT(NEW.full_name,1)) , LCASE(SUBSTRING(NEW.full_name,2)))
END
ログイン後にコピー

以上がMySQL がストアドファンクションとトリガーでのテーブル変更をブロックするのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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