Der Editor unten zeigt Ihnen ein alltägliches MySQL-Ereignis-EreignisScheduler (muss gelesen werden). Ich finde es ziemlich gut, also teile ich es jetzt mit dir und gebe es als Referenz. Lass uns dem Herausgeber folgen und einen Blick darauf werfen.
Übersicht
MySQL verfügt auch über einen eigenen Ereignisplaner, der einfach als Crontab-Job von Linux verstanden werden kann, aber für SQL-Anwendungen sind seine Funktionen umfassender und Ich persönlich habe das Gefühl, dass es die DB-Leistung beeinträchtigen und das Debuggen erschweren kann, wenn zu viele davon erstellt werden.
Der Hauptinhalt von MySQL Event Scheduler
HauptschalterDer Parameter event_scheduler ist der Hauptschalter des Ereignisplaners, es ist gut, ihn auf ON oder OFF zu stellen empfohlen. Auf deaktiviert setzen, wenn auf EIN eingestellt, Prozess anzeigen
Liste
Erstellen, ändern, anzeigen usw. Syntax
Informationen zum Erstellen und Ändern von Ereignissen finden Sie hier. Die spezifische Bedeutung finden Sie in der folgenden Einführung in die Ereignisinformationstabelle Link zum offiziellen Website-Dokument: http://dev.mysql.com/doc/refman/5.6/en/create-event.html
Sehen Sie sich das an Erstelltes Ereignis. Nach Eingabe der aktuellen Datenbank wird „Ereignis erstellen xxxG“ angezeigt
Informationsabfrage und Bedeutung des EreignissesUm die Statusinformationen eines Ereignisses anzuzeigen, können Sie mysql.event oder information_schema.events anzeigen oder einfach zur aktuellen Datenbank wechseln und Show-Ereignisse ausführen. Die Inhalte der drei sind grundsätzlich gleich. information_schema kann die Daten nicht kopieren und die folgenden Namen und Startzeiten wurden zur besseren Lesbarkeit geändert. Die Informationen in information_schema.events werden beispielhaft erläutert
EVENT_CATALOG: ist im Allgemeinen def, unabhängig von
EVENT_SCHEMA: Das Schema, in dem sich das Ereignis befindet
EVENT_NAME: Der Name des Ereignisses
DEFINER: Der Definierer von Ereignis stimmt mit dem Ergebnis überein von selectcurrent_user() standardmäßig bei der Definition dieses Ereignisses. Wenn der Benutzer über super-Berechtigungen verfügt, kann er als anderer Benutzer
TIME_ZONE: Die vom Ereignis verwendete Zeitzone, der Standardwert ist System, es wird empfohlen, sie nicht zu ändern
EVENT_BODY:Es ist normalerweise SQL, machen Sie sich darüber keine Sorgen
EVENT_DEFINITION:Der Inhalt des Ereignisses kann ein bestimmtes SQL sein, z. B. ein Einfügen, oder es kann ein Aufruf seinVorgang einer gespeicherten Prozedur
EVENT_TYPE:Dieser Parameter ist wichtiger. Er wird bei der Definition angegeben. Er hat zwei Werte: RECURRING und ONE TIME, RECURRING. Gibt an, dass er wiederholt ausgeführt wird solange die Bedingungen erfüllt sind und ONE TIME nur einmal aufgerufen wird
EXECUTE_AT:gilt für einmalige Ereignisse, wenn es sich um RECURRING handelt Typereignis ist im Allgemeinen NULL und gibt die geschätzte Ausführungszeit des Ereignisses an.
INTERVAL_VALUE:gilt für Ereignisse vom Typ RECURRING und gibt die Ausführung an Intervalllänge
INTERVAL_FIELD:gilt für Ereignisse vom Typ RECURRING und gibt die Einheit des Ausführungsintervalls an, normalerweise SECOND, DAY und andere Werte. Bitte beachten Sie die Erstellungssyntax
SQL_MODE:SQL_MODE, der vom aktuellen Ereignis verwendet wird
STARTS: gilt für RECURRING Geben Sie Ereignisse ein, die angeben, dass ein Ereignis ab beginnt. Der Zeitpunkt, zu dem die Ausführung beginnt, ähnelt der einmaligen Funktion EXECUTE_AT. Wenn es NULL ist, bedeutet dies, dass die Ausführung beginnt, sobald die Bedingungen erfüllt sind ENDE: gilt für Ereignisse vom Typ RECURRING und gibt den Zeitpunkt an, nach dem ein Ereignis nicht mehr ausgeführt wird. Wenn es NULL ist, wird es niemals gestoppt STATUS: hat im Allgemeinen drei Werte: ENABLED, DISABLED und SLAVESIDE_DISABLED, wobei ENABLED die Aktivierung dieses Ereignisses bedeutet, das ausgeführt wird, solange es andere Bedingungen erfüllt, die das Ereignis erfüllt nicht ausgeführt werden, wenn der DISABLED-Status geändert wird. SLAVESIDE_DISABLED bedeutet, dass das Ereignis nicht auf der Slave-Bibliothek ausgeführt wird. Es muss besonders darauf geachtet werden, keinerlei Ereignis in der Slave-Bibliothek auszuführen, denn wenn die Hauptbibliothek es einmal ausführt, es in die Slave-Bibliothek kopiert und es dann erneut von der Slave-Bibliothek aus ausführt, sind die Daten inkonsistent. Im Allgemeinen deaktivieren Sie einfach das Ereignis in der Slave-Bibliothek. Schalten Sie einfach den Hauptschalter event_scheduler ein. ON_COMPLETION: Es gibt nur zwei Werte, PRESERVE und NOT PRESERVE, PRESERVE CREATED: Die Erstellungszeit des Ereignisses LAST_ALTERED: Die Zeit, zu der das Ereignis zuletzt geändert wurde LAST_EXECUTED: Die letzte Ausführungszeit des Ereignisses. Wenn es NULL ist, bedeutet dies, dass es nie ausgeführt wurde EVENT_COMMENT: Die Kommentarinformationen zum Ereignis Zeichensatz, wenn das Ereignis erstellt wurde , Character_set_client EVENT-Berechtigungsverwaltung Systemvariable, super_priv-Berechtigung ist erforderlich EREIGNIS-Abfrage Verwendungsvorschläge mysql> showglobal status like '%event%';
+--------------------------+-------+
|Variable_name | Value |
+--------------------------+-------+
|Com_alter_event | 0 |
|Com_create_event | 2 |
|Com_drop_event | 2 |
|Com_show_binlog_events | 0 |
|Com_show_create_event | 191 |
|Com_show_events | 40 |
|Com_show_relaylog_events | 0 |
+--------------------------+-------+
7 rows in set(0.00 sec)
Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung des grafischen Codes des MySQL-Event-Event-Planers. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!