ホームページ >データベース >mysql チュートリアル >MySQL トリガーがテーブルを更新しないのはなぜですか?
MySQL トリガーの非アクティブのトラブルシューティング
別のカラムの変更に基づいてカラムを更新することが期待される単純な MySQL トリガーを作成する場合、次のことが重要です。機能を妨げる可能性のある潜在的な問題に対処するため。よくある課題の 1 つは、ストアド関数またはトリガーがすでに使用されているテーブルを変更できないことです。
エラー メッセージ: ステートメントの呼び出しによりテーブルが使用されています
エラー メッセージ「このストアド関数/トリガーを呼び出したステートメントによってすでに使用されているため、ストアド関数/トリガーのテーブル pos_table を更新できません」は、トリガーによって更新されているテーブルが、操作をトリガーしたステートメントによっても使用されていることを示します。この競合により、トリガーが正しく実行されません。
解決策:
この問題を解決するには、BEFORE INSERT トリガーの使用を検討してください。 🎜>AFTER UPDATE トリガー。 BEFORE INSERT トリガーを使用すると、挿入される値をテーブルに保存する前に変更できるため、呼び出し元のステートメントとの競合が排除されます。
さらに、トリガーで NEW キーワードを使用して特定の行の値を更新すると、提供された UPDATE ステートメントで提案されているようにテーブル全体ではなく、変更された行のみが更新されるということです。PTS 計算の簡略化:
最後に、次のことに注意してください。 PTS 値を別の列に保存する必要はない場合があります。 PTS 値は必要に応じて簡単に動的に計算できるため、コードが簡素化され、前述のトリガーの問題が回避されます。以上がMySQL トリガーがテーブルを更新しないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。