SQL
 Computer >> コンピューター >  >> プログラミング >> SQL

SQLトリガー

SQLトリガーは、ユーザーが特定のテーブルを操作したときに発生する他の多くのイベントをトリガーするイベントです。この特定のSQLステートメントは、フォームデータを検証したり、ルールを適用したりするのに役立ちます。

トリガーは、次のイベントの前または後に実行されます。

  • INSERT –新しい行が挿入されたとき。
  • UPDATE –既存の行が更新されたとき。
  • DELETE –行が削除されたとき。

どのトリガーがオフになり、何が発生するかは、トリガーの記述方法によって異なります。 createステートメントを作成することから始めましょう。

CREATE TRIGGER <trigger_name> [BEFORE|AFTER] [INSERT|UPDATE|DELETE]
ON <table_name> [FOR EACH ROW|FOR EACH STATEMENT]
BEGIN
  <trigger_logic>
END;

<>の任意のセットの間で、カスタム名またはロジックに置き換えます。 []内で、利用可能なものから1つ選択します。

BEFORE/AFTERおよびINSERT|UPDATE | DELETE:各リストから1つを選択します。 BEFORE / AFTERは、トリガーがいつ発生するかを決定します。 INSERT / UPDATE / DELETEは、トリガーを開始するために発生するイベントです。

FOR EACH ROW | FOR EACH STATEMENT:ここでの2つの選択肢の違いは、トリガーが実行される回数の違いです。 FOR EACH ROWは、テーブルで影響を受ける各行でトリガーされます。 FOR EACH STATEMENTは、行が更新されているかどうかに関係なく、常に少なくとも1回は実行されることが保証されています。

データベースやテーブルと同様に、DROPTRIGGERオプションがあります:

DROP TRIGGER [IF EXISTS] trigger_name;

IF EXISTSは、構文のオプション部分です。ステートメントブロックに含まれている場合、その部分は「トリガーが存在しません」エラーを防ぎます。削除されたテーブルは、関連するすべてのトリガーも自動的に削除します。

参加者の81%は、ブートキャンプに参加した後、自分たちの技術的な仕事の見通しについてより自信を持っていると述べました。今日のブートキャンプにマッチしましょう。

平均的なブートキャンプの卒業生は、ブートキャンプの開始から最初の仕事を見つけるまで、キャリアの移行に6か月も費やしませんでした。

SQLトリガーには、トリガーに名前とイベントが発生するタイミング、トリガーが発生する頻度、実際のトリガーのロジックをレイアウトするBEGIN/ENDブロックの3つの主要な要素が必要であることを理解してください。

最初に理解できない場合は、練習を続けてください。これはSQLの高度な概念であるため、SQLの他のトピックや関数よりも多くの繰り返しが必要になる可能性があります。


  1. SQL検疫

    このブログ投稿では、SQL検疫の概念を紹介しています。 Oracle®ResourceManagerを使用すると、CPUやI/Oなどのリソースの使用を規制および制限できます。最も興味深い事実は、定義されたしきい値を超える長時間実行クエリの実行を防ぐことができるということです。 SQL検疫とは何ですか? 検疫とは隔離を意味します。 SQL検疫は、暴走クエリのオーバーヘッドを排除するために使用できるバージョン19cの機能です。暴走クエリは、リソースまたはランタイムの制限を超え、リソース、CPU、およびIOの多くを使用するため、ResourceManagerによって終了されるクエリです。 この

  2. それぞれ...またはその他

    eachが大好きです 、しかし私はそれに問題があります。 空のコレクションがあるとどうなりますか? [].eachを呼び出す場合 、何も起こらず、[] 返されます。時々、それはあなたが望むものです。 ただし、特にUIを構築する場合は、空のリストを特別な方法で処理する必要があります。 たとえば、データがない場合は通常、別のメッセージを表示したいと思います。 しかし、[].each以降 []を返します 、nilではありません 、あなたはこのようなものを書くのに行き詰まっています: app / views / users / index.html.erb <% if @users.e