


Verhindern von Tabellenaktualisierungen mithilfe von MySQL-Triggern mit Fehlerbehandlung
MySQL bietet einen leistungsstarken Mechanismus zur Durchsetzung von Datenintegrität und Geschäftsregeln durch Trigger. Ein kritisches Szenario besteht darin, nicht autorisierte oder ungültige Aktualisierungen einer Tabelle zu verhindern. In diesem Artikel wird gezeigt, wie Sie MySQL-Trigger nutzen, um Fehler auszulösen und solche Aktualisierungen zu verhindern.
Fehler in Triggern auslösen
Ab MySQL 5.5 ermöglicht die SIGNAL-Syntax Entwicklern das Auslösen Ausnahmen innerhalb von Triggern. Die SIGNAL-Anweisung benötigt zwei Parameter:
SIGNAL sqlstate SET message_text = 'Error Message';
wobei sqlstate den Ausnahmetyp angibt und message_text die benutzerdefinierte Fehlermeldung definiert. Der Ausnahmetyp sollte ein fünfstelliger Code sein, der die entsprechende Fehlerbedingung darstellt.
Erstellen eines benutzerdefinierten Auslösers für die Fehlerbehandlung
Betrachten Sie das folgende Beispiel: Sie möchten verhindern Aktualisiert eine Tabelle, wenn der neue Wert einer bestimmten Spalte negativ ist. Um dies zu erreichen, erstellen Sie vor dem Aktualisierungsvorgang einen Trigger wie folgt:
CREATE TRIGGER trg_before_update BEFORE UPDATE ON my_table FOR EACH ROW BEGIN DECLARE msg VARCHAR(128); IF NEW.column_name <p>Der Trigger prüft, ob der neue Wert der Spalte „column_name“ negativ ist. Wenn dies der Fall ist, erstellt es eine benutzerdefinierte Fehlermeldung und löst mithilfe der SIGNAL-Anweisung eine Ausnahme aus. Der 45000 SQLSTATE stellt eine nicht behandelte benutzerdefinierte Ausnahme dar.</p><p><strong>Testen des Triggers</strong></p><p>Führen Sie die folgenden Anweisungen aus, um den Trigger zu testen:</p><pre class="brush:php;toolbar:false">-- Insert valid and invalid data: INSERT INTO my_table (column_name) VALUES (1), (-1), (2); -- Display the table contents: SELECT * FROM my_table; -- Attempt to insert invalid data: INSERT INTO my_table (column_name) VALUES (-1);
Die erste INSERT-Anweisung schlägt fehl, da eine Zeile einen negativen Wert enthält, was den im Trigger definierten benutzerdefinierten Fehler auslöst. Die nachfolgende INSERT-Anweisung schlägt ebenfalls fehl, da der Trigger Aktualisierungen mit negativen Werten verhindert.
Das obige ist der detaillierte Inhalt vonWie können MySQL-Trigger Tabellenaktualisierungen verhindern und Fehler behandeln?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

In dem Artikel werden mithilfe der Änderungstabelle von MySQL Tabellen, einschließlich Hinzufügen/Löschen von Spalten, Umbenennung von Tabellen/Spalten und Ändern der Spaltendatentypen, erläutert.

In Artikel werden die Konfiguration der SSL/TLS -Verschlüsselung für MySQL, einschließlich der Erzeugung und Überprüfung von Zertifikaten, erläutert. Das Hauptproblem ist die Verwendung der Sicherheitsauswirkungen von selbstsignierten Zertifikaten. [Charakterzahl: 159]

In Artikel werden Strategien zum Umgang mit großen Datensätzen in MySQL erörtert, einschließlich Partitionierung, Sharding, Indexierung und Abfrageoptimierung.

In Artikel werden beliebte MySQL -GUI -Tools wie MySQL Workbench und PhpMyAdmin beschrieben, die ihre Funktionen und ihre Eignung für Anfänger und fortgeschrittene Benutzer vergleichen. [159 Charaktere]

In dem Artikel werden in MySQL die Ablagerung von Tabellen mithilfe der Drop -Tabellenerklärung erörtert, wobei Vorsichtsmaßnahmen und Risiken betont werden. Es wird hervorgehoben, dass die Aktion ohne Backups, die Detaillierung von Wiederherstellungsmethoden und potenzielle Produktionsumfeldgefahren irreversibel ist.

In dem Artikel werden in verschiedenen Datenbanken wie PostgreSQL, MySQL und MongoDB Indizes für JSON -Spalten in verschiedenen Datenbanken erstellt, um die Abfrageleistung zu verbessern. Es erläutert die Syntax und die Vorteile der Indizierung spezifischer JSON -Pfade und listet unterstützte Datenbanksysteme auf.

In Artikeln werden ausländische Schlüssel zur Darstellung von Beziehungen in Datenbanken erörtert, die sich auf Best Practices, Datenintegrität und gemeinsame Fallstricke konzentrieren.

Artikel erläutert die Sicherung von MySQL gegen SQL-Injektions- und Brute-Force-Angriffe unter Verwendung vorbereiteter Aussagen, Eingabevalidierung und starken Kennwortrichtlinien (159 Zeichen).


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

mPDF
mPDF ist eine PHP-Bibliothek, die PDF-Dateien aus UTF-8-codiertem HTML generieren kann. Der ursprüngliche Autor, Ian Back, hat mPDF geschrieben, um PDF-Dateien „on the fly“ von seiner Website auszugeben und verschiedene Sprachen zu verarbeiten. Es ist langsamer und erzeugt bei der Verwendung von Unicode-Schriftarten größere Dateien als Originalskripte wie HTML2FPDF, unterstützt aber CSS-Stile usw. und verfügt über viele Verbesserungen. Unterstützt fast alle Sprachen, einschließlich RTL (Arabisch und Hebräisch) und CJK (Chinesisch, Japanisch und Koreanisch). Unterstützt verschachtelte Elemente auf Blockebene (wie P, DIV),

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

DVWA
Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

VSCode Windows 64-Bit-Download
Ein kostenloser und leistungsstarker IDE-Editor von Microsoft