29

私のMySQLデータベースには、いくつかのトリガーON DELETEON INSERT. DROP場合によっては、いくつかのトリガーを無効にする必要があります。

DROP TRIGGER IF EXISTS hostgroup_before_insert //   

そして再インストール。SET triggers hostgroup_before_insert = 0外部キーのようなショートカットはありますか:

mysql> SELECT version();
+-------------------------+
| version()               |
+-------------------------+
| 5.1.61-0ubuntu0.10.10.1 |
+-------------------------+
1 row in set (0.00 sec)

EDIT Answer MySQL には組み込みのサーバー システム変数 TRIGGER_CHECKS はありません
簡単な回避策は、代わりにユーザー定義のセッション変数を使用することです。

#FALSE value overrides trigger type settings
SET @TRIGGER_CHECKS = [TRUE|FALSE]; 

SET @TRIGGER_BEFORE_INSERT_CHECKS = [TRUE|FALSE];
SET @TRIGGER_AFTER_INSERT_CHECKS = [TRUE|FALSE];

DELIMITER $$
DROP TRIGGER IF EXISTS `yearCheck_beforeInsert` $$
CREATE DEFINER=`root`@`localhost` TRIGGER `yearCheck_beforeInsert`
BEFORE INSERT ON `movies` FOR EACH ROW 

#Patch starts here
thisTrigger: BEGIN
  IF ((@TRIGGER_CHECKS = FALSE)
      OR (@TRIGGER_BEFORE_INSERT_CHECKS = FALSE))
    AND (USER() = 'root@localhost') 

このトリックはここで説明されています

4

1 に答える 1

12

トリガーを一時的に無効にすることはできません。1 つのことを行い、1 つのグローバル変数を使用します。トリガーは、最初にグローバル変数の値を最初にチェックします。この場合、グローバル変数の値を変更して、トリガーが機能しないようにすることができます。

于 2012-11-28T05:15:21.450 に答える