Kapitel 20. Durchführung von Transaktionen
Diese Arbeit wurde mithilfe von KI übersetzt. Wir freuen uns über dein Feedback und deine Kommentare: translation-feedback@oreilly.com
20.0 Einleitung
Der MySQL-Server kann mehrere Clients gleichzeitig bearbeiten weil er multithreaded ist. Um mit Konflikten zwischen den Clients umzugehen, führt der Server alle notwendigen Sperrungen durch, damit nicht zwei Clients gleichzeitig dieselben Daten ändern können. Wenn der Server SQL-Anweisungen ausführt, ist es jedoch sehr gut möglich, dass aufeinanderfolgende Anweisungen von einem bestimmten Client mit Anweisungen von anderen Clients verschachtelt werden. Wenn ein Client mehrere Anweisungen ausführt, die voneinander abhängig sind, kann die Tatsache, dass andere Clients zwischen diesen Anweisungen Tabellen aktualisieren, zu Schwierigkeiten führen.
Anweisungsfehler können ebenfalls problematisch sein, wenn eine Operation mit mehreren Anweisungen nicht zu Ende geführt wird. Angenommen, eine Tabelle flight enthält Informationen über Flugpläne von Fluggesellschaften und du möchtest die Zeile für Flug 578 aktualisieren, indem du einen Piloten aus den verfügbaren auswählst. Du könntest dies mit den folgenden drei Anweisungen tun:
SET@p_val=(SELECTpilot_idFROMpilotWHEREavailable='yes'LIMIT1);UPDATEpilotSETavailable='no'WHEREpilot_id=@p_val;UPDATEflightSETpilot_id=@p_valWHEREflight_id=578;
Die erste Anweisung wählt einen verfügbaren Piloten aus, die zweite markiert den Piloten ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Read now
Unlock full access