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

เราจะแก้ไขเหตุการณ์ MySQL ที่มีอยู่ได้อย่างไร


ด้วยความช่วยเหลือของคำสั่ง ALTER EVENT เราสามารถแก้ไขเหตุการณ์ MySQL ที่มีอยู่ได้ เราสามารถเปลี่ยนแอตทริบิวต์ต่างๆ ของเหตุการณ์ได้ ALTER EVENT มีรูปแบบดังนี้ -

   ALTER EVENT event_name
    ON SCHEDULE schedule
ON COMPLETION [NOT] PRESERVE
  RENAME TO new_event_name
    ENABLE | DISABLE
           DO
       event_body

เพื่อให้เข้าใจตรงกัน เราจะยกตัวอย่างดังต่อไปนี้ −

ตัวอย่าง

สมมติว่าเรามีเหตุการณ์ดังต่อไปนี้ -

mysql> Create event hello ON SCHEDULE EVERY 1 Minute DO INSERT INTO event_messages(message, generated_at) Values ('Alter event testing', NOW());
Query OK, 0 rows affected (0.00 sec)

mysql> select * from event_messages;
+----+---------------------+---------------------+
| ID | MESSAGE             | Generated_at        |
+----+---------------------+---------------------+
|  1 | Without Preserve    | 2017-11-22 20:32:13 |
|  2 | With Preserve       | 2017-11-22 20:35:12 |
|  3 | Alter event testing | 2017-11-22 21:08:37 |
+----+---------------------+---------------------+
3 rows in set (0.00 sec)

mysql> ALTER EVENT hello ON SCHEDULE EVERY 2 MINUTE;
Query OK, 0 rows affected (0.00 sec)

ข้อความค้นหาด้านบนจะเปลี่ยนกำหนดการของกิจกรรมจาก 1 นาทีเป็น 2 นาที และข้อความค้นหาด้านล่างจะเปลี่ยนเนื้อหาของกิจกรรม

mysql> ALTER EVENT hello DO INSERT INTO event_messages(message,generated_at) VALUES('ALTERED',NOW());
Query OK, 0 rows affected (0.00 sec)

mysql> select * from event_messages;
+----+---------------------+---------------------+
| ID | MESSAGE             | Generated_at        |
+----+---------------------+---------------------+
|  1 | Without Preserve    | 2017-11-22 20:32:13 |
|  2 | With Preserve       | 2017-11-22 20:35:12 |
|  3 | Alter event testing | 2017-11-22 21:08:37 |
|  4 | Alter event testing | 2017-11-22 21:09:15 |
|  5 | ALTERED             | 2017-11-22 21:11:15 |
+----+---------------------+---------------------+
5 rows in set (0.00 sec)

ชุดผลลัพธ์ข้างต้นแสดงว่าเราได้รับข้อความที่เปลี่ยนแปลงหลังจากผ่านไป 2 นาที