Heim  >  Artikel  >  Datenbank  >  MySQL lernt Transaktionskontrolle

MySQL lernt Transaktionskontrolle

coldplay.xixi
coldplay.xixinach vorne
2021-04-07 09:32:192736Durchsuche

MySQL lernt Transaktionskontrolle

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.

  • In MySQL unterstützen nur Datenbanken oder Tabellen, die die Speicher-Engine Innodb verwenden, Transaktionen.
  • Transaktionen werden verwendet, um die Integrität der Datenbank aufrechtzuerhalten und sicherzustellen, dass Stapel von SQL-Anweisungen entweder ausgeführt oder nicht ausgeführt werden.
  • Transaktionen Früher Verwalten Sie die Kontoauszüge INSERT, UPDATE und DELETE

Wenn Zhang San am Geldautomaten 100 Yuan an Li Si überweist, werden im Geschäftssystem der Bank zweistufige Datenänderungsvorgänge durchgeführt:

  1. 100 Yuan vom Konto von Zhang San abziehen
  2. 100 Yuan zum Konto von Li Si hinzufügen

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).

  • Atomizität: Die Transaktion muss eine atomare Arbeitseinheit sein und jede in der Transaktion enthaltene Operation muss ausgeführt werden oder nicht.
  • Konsistenz: Wenn die Transaktion abgeschlossen ist, müssen alle Daten in einem konsistenten Zustand sein.
  • Isolationsmerkmale: Transaktionen laufen unabhängig ab. Mehrere Transaktionen sind voneinander isoliert und stören sich nicht gegenseitig. Eine 100-prozentige Isolierung von Transaktionen geht zu Lasten der Geschwindigkeit.
  • Persistenz: Nachdem eine Transaktion ausgeführt wurde, ist ihre Auswirkung auf das System dauerhaft.

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

oder

Begin 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 an

USE student;SHOW TABLES;

    2. Erstellen Sie die Datentabelle „bank_account“ und fügen Sie zwei Datensätze ein, stellen Sie den Wert des Kontostandfelds von Zhang San auf +1000
  • 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;
    MySQL lernt Transaktionskontrolle
  • 3. Standard-Autocommit-Wert anzeigen MySQL lernt Transaktionskontrolle
    SELECT @@autocommit;

4. Alle Datensätze in der Datentabelle „bank_account“ anzeigen

SELECT * FROM bank_account;

    5. Transaktionssteuerung starten und zwei SQL-Anweisungen ausführen
  1. 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 MySQL lernt Transaktionskontrolle

SELECT * FROM bank_account;

7. Starten Sie die Transaktionssteuerung erneut, fügen Sie die gleichen beiden SQL-Anweisungen ein, ändern Sie jedoch Commit in RollbackMySQL lernt Transaktionskontrolle

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-ÄnderungenMySQL lernt Transaktionskontrolle

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!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen