Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> MySQL

เราจะตรวจสอบรายการทริกเกอร์ทั้งหมดในฐานข้อมูลได้อย่างไร


ด้วยความช่วยเหลือของคำสั่ง SHOW TRIGGERS เราสามารถแสดงรายการทริกเกอร์ทั้งหมดในฐานข้อมูลหนึ่งๆ สามารถอธิบายได้โดยใช้ตัวอย่างต่อไปนี้ −

ตัวอย่าง

mysql> Show Triggers\G
*************************** 1. row ***************************
  Trigger: trigger_before_delete_sample
    Event: DELETE
    Table: sample
Statement: BEGIN

SET @count = if (@count IS NULL, 1, (@count+1));
INSERT INTO sample_rowaffected values (@count);
END

  Timing: BEFORE
 Created: 2017-11-21 12:31:58.70
sql_mode:

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERR
OR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
             Definer: root@localhost
character_set_client: cp850
collation_connection: cp850_general_ci
  Database Collation: latin1_swedish_ci
*************************** 2. row ***************************
  Trigger: before_inser_studentage
    Event: INSERT
    Table: student_age
Statement: IF NEW.age < 0 THEN SET NEW.age = 0;
END IF
  Timing: BEFORE
 Created: 2017-11-21 11:26:15.34
sql_mode:

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERR
OR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

             Definer: root@localhost
character_set_client: cp850
collation_connection: cp850_general_ci
  Database Collation: latin1_swedish_ci
2 rows in set (0.01 sec)

ชุดผลลัพธ์ด้านบนแสดงรายการทริกเกอร์ในฐานข้อมูลปัจจุบัน ตอนนี้ หากเราต้องการรับรายการทริกเกอร์ในฐานข้อมูลใดฐานข้อมูลหนึ่ง เราก็สามารถใช้คำสั่งต่อไปนี้ -

mysql> Show Triggers from tutorials\G
Empty set (0.00 sec)

ชุดผลลัพธ์ข้างต้นแสดงว่าไม่มีทริกเกอร์ในฐานข้อมูลชื่อ 'บทช่วยสอน'