sql >> データベース >  >> RDS >> Mysql

MySQLは、変更が発生したときに通知を受け取ることができるように、Cでのコールバックを許可していますか?

    そのようなトリガーを作成します。

    DELIMITER $$
    
    CREATE TRIGGER ad_mytable_each AFTER DELETE ON MyTable FOR EACH ROW
    BEGIN
      #write code that trigger After delete (hence the "ad_" prefix)
      #For table MyTable (The _MyTable_ middle)
      #On each row that gets inserted (_each suffix)
      #
      #You can see the old delete values by accesing the "old" virtual table.
      INSERT INTO log VALUES (old.id, 'MyTable', old.field1, old.field2, now());
    
    END$$
    
    DELIMITER ;
    

    INSERTのトリガーがあります 、DELETEUPDATE
    そして彼らはBEFOREを発砲することができます またはAFTER アクション。
    トリガーBEFORE アクションは、そのようにエラーを強制することによってアクションをキャンセルできます。

    CREATE TRIGGER bd_mytable_each BEFORE DELETE ON MyTable FOR EACH ROW
    BEGIN
      #write code that trigger Before delete (hence the "db_" prefix)
      declare DoError Boolean; 
    
      SET DoError = 0;
    
      IF old.id = 1 THEN SET DoError = 1; END IF; 
    
      IF (DoError = 1) THEN SELECT * FROM Table_that_does_not_exist_to_force_error;
      #seriously this example is in the manual.
    
    END$$
    
    DELIMITER ;
    

    これにより、レコード1の削除が防止されます。

    before UPDATEトリガーは、更新された値を変更することもできます。

    CREATE TRIGGER bu_mytable_each BEFORE UPDATE ON MyTable FOR EACH ROW
    BEGIN
      IF new.text = 'Doon sucks' THEN SET new.text = 'Doon rules';
    END$$
    
    DELIMITER ;
    

    トリガーが幸せになることを願っています。



    1. グループごとに不足している日付を埋める

    2. MySQL4.0で作成されたタイムスタンプ列と最終更新されたタイムスタンプ列の両方を持つ

    3. MySQLで列の名前を変更中にエラーが発生しました

    4. SQLサーバースキーマとデフォルトスキーマ