Heim > Datenbank > MySQL-Tutorial > 在MySQL中使用触发器Trigger的操作过程

在MySQL中使用触发器Trigger的操作过程

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Freigeben: 2016-06-07 16:39:46
Original
1408 Leute haben es durchsucht

想监控Bugzilla数据库中几个重要的表,如果它们发生了任何改变(增、删、改),都希望能够记录下来,以便后面再写程序来分析。很自然,就想到使用MySQL的触发器(Trigger)了,学习了一会,记录如下: 1. 先建立一个新的表用于记录我需要的变化: CREATE TAB

想监控Bugzilla数据库中几个重要的表,如果它们发生了任何改变(增、删、改),都希望能够记录下来,以便后面再写程序来分析。很自然,就想到使用MySQL的触发器(Trigger)了,学习了一会,记录如下:
1. 先建立一个新的表用于记录我需要的变化:

CREATE TABLE `bugzilla_log` (
  `id` INT UNSIGNED NOT NULL,
  `table` varchar(80) NOT NULL,
  `action` ENUM('insert','update','delete'),
  `ts` TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='logging some important changes in bugzilla DB';
Nach dem Login kopieren


2. 针对需要监控的表,创建触发器:

CREATE
    TRIGGER `classifications_insert`
    AFTER INSERT
    ON classifications FOR EACH ROW
    INSERT INTO `bugzilla_log` (`id`, `table`, `action`, `ts`) VALUES (NEW.id, 'classifications', 'insert', NOW()); 
?
CREATE
    TRIGGER `classifications_update`
    AFTER UPDATE
    ON classifications FOR EACH ROW
    INSERT INTO `bugzilla_log` (`id`, `table`, `action`, `ts`) VALUES (NEW.id, 'classifications', 'update', NOW()); 
?
CREATE
    TRIGGER `classifications_delete`
    BEFORE DELETE
    ON classifications FOR EACH ROW
    INSERT INTO `bugzilla_log` (`id`, `table`, `action`, `ts`) VALUES (OLD.id, 'classifications', 'delete', NOW());
Nach dem Login kopieren

请注意其中AFTER和BEFORE,以及OLD和NEW的使用。
Within the trigger body, you can refer to columns in the subject table (the table associated with the trigger) by using the aliases OLD and NEW. OLD.col_name refers to a column of an existing row before it is updated or deleted. NEW.col_name refers to the column of a new row to be inserted or an existing row after it is updated.

3. 查看当前数据库中的触发器:

SHOW TRIGGERS;
Nach dem Login kopieren

参考资料:

http://dev.mysql.com/doc/refman/5.5/en/create-trigger.html

http://www.jicdesign.com/blog/web-development/how-to-use-mysql-triggers-to-log-table-changes.html

Original article: 在MySQL中使用触发器Trigger的操作过程

©2014 笑遍世界. All Rights Reserved.

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Aktuelle Ausgaben
So ändern Sie MySQL in MySQL
Aus 1970-01-01 08:00:00
0
0
0
MySQL-Startfehler unter Centos
Aus 1970-01-01 08:00:00
0
0
0
MySQL stoppt den Prozess
Aus 1970-01-01 08:00:00
0
0
0
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage