Was ist Transaktionskontrolle
Eine Transaktion bezieht sich auf eine Reihe von Vorgängen, die als logische Arbeitseinheit ausgeführt werden, wobei die Vorgänge entweder alle erfolgreich sind, oder alle fehlschlagen. Transaktionen stellen sicher, dass mehrere Datenänderungen als Einheit verarbeitet werden.
Wenn Zhang San am Geldautomaten 100 Yuan an Li Si überweist, werden im Geschäftssystem der Bank zweistufige Datenänderungsvorgänge durchgeführt:
Was passiert, wenn Vorgang 1 erfolgreich ausgeführt wird und Vorgang 2 fehlschlägt?
Verwandte kostenlose Lernempfehlungen: MySQL-Video-Tutorial
Vier Merkmale von Transaktionen
Wenn eine Datenbank Transaktionen unterstützt, muss die Datenbank ACIDvier Merkmale aufweisen, nämlich Atomizität( Atomizität), Konsistenz (Konsistenz), Isolation (Isolation), Haltbarkeit (Persistenz).
Transaktionskontrolle von MySQL. Standardmäßig sendet MySQL automatisch eine Transaktion , führt jede SQL-Anweisung von INSERT, UPDATE und DELETE die COMMIT-Operation unmittelbar nach der Übermittlung aus. Um eine Transaktion zu starten, können Sie daher Start Transaction
oderBegin verwenden oder den Wert von Autocommit auf 0 setzen le Melden Sie sich bei der Datenbank an, verwenden Sie die Studentendatenbank und sehen Sie sich alle Datentabellen anUSE student;SHOW TABLES;
CREATE TABLE bank_account( id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, name VARCHAR(30) COMMENT '姓名', balance DECIMAL(18, 2) COMMENT '账户余额');INSERT INTO bank_account(id, name, balance) VALUE(1, '张三', 0);INSERT INTO bank_account(id, name, balance) VALUE(2, '李四', 0);UPDATE bank_account SET balance = balance + 1000 WHERE id = 1;
SELECT @@autocommit;
4. Alle Datensätze in der Datentabelle „bank_account“ anzeigen SELECT * FROM bank_account;
START TRANSACTION;UPDATE bank_account SET balance = balance - 100 WHERE id = 1;UPDATE bank_account SET balance = balance + 100 WHERE id = 2;COMMIT;
6. Inhalte der Datentabelle anzeigen zu diesem Zeitpunkt
SELECT * FROM bank_account;
7. Starten Sie die Transaktionssteuerung erneut, fügen Sie die gleichen beiden SQL-Anweisungen ein, ändern Sie jedoch Commit in Rollback
START TRANSACTION;UPDATE bank_account SET balance = balance - 100 WHERE id = 1;UPDATE bank_account SET balance = balance + 100 WHERE id = 2;ROLLBACK;
8. Überprüfen Sie den Inhalt der Datentabelle erneut und stellen Sie fest, dass danach keine Daten mehr vorhanden sind Rollback-Änderungen
SELECT * FROM bank_account;
Hinweis: Dieser Artikel ist eine Zusammenfassung des MySQL-Lernens des Bloggers und unterstützt keine kommerzielle Nutzung. Bitte geben Sie beim Nachdruck die Quelle an! Wenn Sie auch ein gewisses Interesse und Verständnis für das MySQL-Lernen haben, können Sie gerne mit Bloggern kommunizieren
Das obige ist der detaillierte Inhalt vonMySQL lernt Transaktionskontrolle. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!