suchen
HeimBackend-EntwicklungPHP-TutorialBeispiel für die PHP-MySQL-Transaktionsverarbeitung

Transaktionen müssen 4 Bedingungen (ACID) erfüllen: Atomizität (Autmic), Konsistenz (Consistency), Isolation (Isolation), Haltbarkeit (Durability)

Atomicity (Autmic): Transaktion In Bezug auf die Ausführung ist dies der Fall notwendig, um „entweder nicht zu tun, oder alles zu tun!“ zu erreichen, was bedeutet, dass ein Teil der Transaktion nicht ausgeführt werden darf. Auch wenn die Transaktion aufgrund eines Fehlers nicht abgeschlossen werden kann, müssen die Auswirkungen auf die Datenbank beim Rollback beseitigt werden!

Konsistenz: Der Transaktionsvorgang sollte die Datenbank von einem konsistenten Zustand in einen anderen konsistenten Zustand umwandeln! Nehmen wir als Beispiel den Online-Einkauf: Sie können nur dann ein Geschäft machen, wenn Sie die Ware aus dem Lager holen und in den Warenkorb des Kunden legen!

Isolation: Wenn mehrere Transaktionen gleichzeitig ausgeführt werden, sollte es so sein, als ob jede Transaktion unabhängig ausgeführt würde!

Dauerhaftigkeit: Eine erfolgreich ausgeführte Transaktion wirkt sich nachhaltig auf die Datenbank aus. Selbst wenn die Datenbank ausfällt und ein Fehler auftritt, sollte sie wiederhergestellt werden können!

Es gibt zwei Hauptmethoden der Transaktionsverarbeitung in MYSQL.
1. Verwenden Sie begin, rollback und commit, um
begin, um eine Transaktion zu starten.
rollback, um die Transaktion zurückzusetzen.
commit, um die Transaktion zu bestätigen.
rollback und commit können nicht parallel verwendet werden. Wenn Sie sie gleichzeitig verwenden, ist nur die erstere gültig, die letztere ist jedoch ungültig, d. h. Sie führen entweder Commit oder Rollback aus
2. Verwenden Sie set direkt, um den automatischen Übermittlungsmodus von MySQL zu ändern
MYSQL sendet standardmäßig automatisch, das heißt, Sie senden eine ABFRAGE. Sie wird einfach ausgeführt! Wir können die Transaktionsverarbeitung implementieren, indem wir
autocommit=0 setzen, um die automatische Übermittlung zu deaktivieren
autocommit=1 setzen und die automatische Übermittlung aktivieren
.

Beachten Sie, dass bei Verwendung von set autocommit=0 alle Ihre nachfolgenden SQL-Anweisungen als Transaktionen verarbeitet werden, bis Sie sie mit Commit oder Rollback bestätigen. Beachten Sie, dass Sie beim Beenden dieser Transaktion auch eine Transaktion eröffnen ! Nach der ersten Methode wird nur die aktuelle als Transaktion verwendet!

Nur ​​Datentabellen vom Typ INNODB und BDB in MYSQL können die Transaktionsverarbeitung unterstützen! Andere Typen werden nicht unterstützt!
***: Im Allgemeinen ist die Standard-Engine der MYSQL-Datenbank MyISAM. Diese Engine unterstützt keine Transaktionen! Wenn Sie möchten, dass MYSQL Transaktionen unterstützt, können Sie es manuell ändern:
Die Methode ist wie folgt: 1. Ändern Sie die Datei c:appservmysqlmy.ini, suchen Sie „skip-InnoDB“, fügen Sie # vor und speichern Sie die Datei.
2. Geben Sie während des Betriebs „services.msc“ ein, um den MySQL-Dienst neu zu starten.
3. Gehen Sie zu phpmyadmin, mysql->show-Engines (oder führen Sie mysql->show-Variablen wie „have_%“ aus) und überprüfen Sie InnoDB auf JA, was bedeutet, dass die Datenbank InnoDB unterstützt.
Das bedeutet, dass Transaktionstransaktionen unterstützt werden.
4. Beim Erstellen einer Tabelle können Sie die InnoDB-Engine für die Storage Engine auswählen. Wenn es sich um eine zuvor erstellte Tabelle handelt, können Sie mysql->alter table table_name type=InnoDB;
oder mysql->alter table table_name engine=InnoDB; verwenden, um die Engine der Datentabelle so zu ändern, dass Transaktionen unterstützt werden.

Beispiel 1.

  $conn = mysql_connect('localhost','root','root') or die ("数据连接错误!!!"); 
    mysql_select_db('test',$conn); 
    mysql_query("set names 'GBK'"); //使用GBK中文编码; 
    //开始一个事务 
    mysql_query("BEGIN"); //或者mysql_query("START TRANSACTION"); 
    $sql = "INSERT INTO `user` (`id`, `username`, `sex`) VALUES (NULL, 'test1', '0')"; 
    $sql2 = "INSERT INTO `user` (`did`, `username`, `sex`) VALUES (NULL, 'test1', '0')";//这条我故意写错 
    $res = mysql_query($sql); 
    $res1 = mysql_query($sql2);  
    if($res && $res1){ 
    mysql_query("COMMIT"); 
    echo '提交成功。'; 
    }else{ 
    mysql_query("ROLLBACK"); 
    echo '数据回滚。'; 
    } 
    mysql_query("END");

Beispiel 2

  mysql_query("SET AUTOCOMMIT=0"); //设置mysql不自动提交,需自行用commit语句提交 
    $sql = "INSERT INTO `user` (`id`, `username`, `sex`) VALUES (NULL, 'test1', '0')"; 
    $sql2 = "INSERT INTO `user` (`did`, `username`, `sex`) VALUES (NULL, 'test1', '0')";//这条我故意写错 
    $res = mysql_query($sql); 
    $res1 = mysql_query($sql2);  
    if($res && $res1){ 
    mysql_query("COMMIT"); 
    echo '提交成功。'; 
    }else{ 
    mysql_query("ROLLBACK"); 
    echo '数据回滚。'; 
    } 
    mysql_query("END"); //事务处理完时别忘记mysql_query("SET AUTOCOMMIT=1");自动提交

Für MyISAM-Engine-Datenbanken, die keine Transaktionen unterstützen, können Sie die Tabelle verwenden Sperrmethode

//MyISAM & InnoDB werden unterstützt,
/*
LOCK TABLES kann die Tabelle für den aktuellen Thread sperren. Wenn die Tabelle von einem anderen Thread gesperrt wird, erfolgt die Blockierung, bis alle Sperren erworben werden können.
UNLOCK TABLES hebt alle vom aktuellen Thread gehaltenen Sperren auf. Wenn ein Thread ein weiteres LOCK TABLES ausgibt oder wenn die Verbindung zum Server geschlossen wird, werden alle vom aktuellen Thread gesperrten Tabellen implizit entsperrt.
*/

mysql_query("LOCK TABLES `user` WRITE");//锁住`user`表 
    $sql = "INSERT INTO `user` (`id`, `username`, `sex`) VALUES (NULL, 'test1', '0')"; 
    $res = mysql_query($sql); 
    if($res){ 
    echo '提交成功。!'; 
    }else{ 
    echo '失败!'; 
    } 
    mysql_query("UNLOCK TABLES");//解除锁定


Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Jenseits des Hype: Beurteilung der Rolle von PHP heute heuteJenseits des Hype: Beurteilung der Rolle von PHP heute heuteApr 12, 2025 am 12:17 AM

PHP bleibt ein leistungsstarkes und weit verbreitetes Tool in der modernen Programmierung, insbesondere im Bereich der Webentwicklung. 1) PHP ist einfach zu bedienen und nahtlos in Datenbanken integriert und für viele Entwickler die erste Wahl. 2) Es unterstützt die Erzeugung der dynamischen Inhalte und die objektorientierte Programmierung, die für die schnelle Erstellung und Wartung von Websites geeignet sind. 3) Die Leistung von PHP kann verbessert werden, indem Datenbankabfragen zwischengespeichert und optimiert werden, und die umfangreiche Community und sein reiches Ökosystem machen es im heutigen Technologiestack immer noch wichtig.

Was sind schwache Referenzen in PHP und wann sind sie nützlich?Was sind schwache Referenzen in PHP und wann sind sie nützlich?Apr 12, 2025 am 12:13 AM

In PHP werden schwache Referenzen in der WeaPreference -Klasse implementiert und verhindern nicht, dass der Müllsammler Objekte zurückerobern. Schwache Referenzen eignen sich für Szenarien wie Caching -Systeme und Event -Hörer. Es ist zu beachten, dass es das Überleben von Objekten nicht garantieren kann und dass die Müllsammlung möglicherweise verzögert wird.

Erklären Sie die __invoke magische Methode in PHP.Erklären Sie die __invoke magische Methode in PHP.Apr 12, 2025 am 12:07 AM

Mit der \ _ \ _ -Invoke -Methode können Objekte wie Funktionen bezeichnet werden. 1. Definieren Sie die Methode \ _ \ _, damit das Objekt aufgerufen werden kann. 2. Bei Verwendung der Syntax $ OBJ (...) wird PHP die Methode \ _ \ _ aufrufen. 3.. Geeignet für Szenarien wie Protokollierung und Taschenrechner, Verbesserung der Codeflexibilität und Lesbarkeit.

Erklären Sie Fasern in PHP 8.1 für die Parallelität.Erklären Sie Fasern in PHP 8.1 für die Parallelität.Apr 12, 2025 am 12:05 AM

Fasern wurde in Php8.1 eingeführt, wodurch die gleichzeitigen Verarbeitungsfunktionen verbessert wurden. 1) Fasern ist ein leichtes Parallelitätsmodell, das Coroutinen ähnelt. 2) Sie ermöglichen es den Entwicklern, den Ausführungsfluss von Aufgaben manuell zu steuern, und eignen sich zum Umgang mit E/O-intensiven Aufgaben. 3) Die Verwendung von Fasern kann effizientere und reaktionsschnelle Code schreiben.

Die PHP -Community: Ressourcen, Unterstützung und EntwicklungDie PHP -Community: Ressourcen, Unterstützung und EntwicklungApr 12, 2025 am 12:04 AM

Die PHP -Community bietet umfangreiche Ressourcen und Unterstützung, um Entwicklern zu helfen, zu wachsen. 1) Zu den Ressourcen gehören offizielle Dokumentation, Tutorials, Blogs und Open -Source -Projekte wie Laravel und Symfony. 2) Die Unterstützung kann durch Stackoverflow-, Reddit- und Slack -Kanäle erhalten werden. 3) Entwicklungstrends können durch Befolgung von RFC gelernt werden. 4) Die Integration in die Community kann durch aktive Teilnahme, Beitrag zum Code und Lernfreigabe erreicht werden.

PHP vs. Python: Verständnis der UnterschiedePHP vs. Python: Verständnis der UnterschiedeApr 11, 2025 am 12:15 AM

PHP und Python haben jeweils ihre eigenen Vorteile, und die Wahl sollte auf Projektanforderungen beruhen. 1.PHP eignet sich für die Webentwicklung mit einfacher Syntax und hoher Ausführungseffizienz. 2. Python eignet sich für Datenwissenschaft und maschinelles Lernen mit präziser Syntax und reichhaltigen Bibliotheken.

PHP: Stirbt es oder passt es sich einfach an?PHP: Stirbt es oder passt es sich einfach an?Apr 11, 2025 am 12:13 AM

PHP stirbt nicht, sondern sich ständig anpasst und weiterentwickelt. 1) PHP hat seit 1994 mehreren Versionen für die Version unterzogen, um sich an neue Technologietrends anzupassen. 2) Es wird derzeit in E-Commerce, Content-Management-Systemen und anderen Bereichen häufig verwendet. 3) PHP8 führt den JIT -Compiler und andere Funktionen ein, um die Leistung und Modernisierung zu verbessern. 4) Verwenden Sie Opcache und befolgen Sie die PSR-12-Standards, um die Leistung und die Codequalität zu optimieren.

Die Zukunft von PHP: Anpassungen und InnovationenDie Zukunft von PHP: Anpassungen und InnovationenApr 11, 2025 am 12:01 AM

Die Zukunft von PHP wird erreicht, indem sich an neue Technologietrends angepasst und innovative Funktionen eingeführt werden: 1) Anpassung an Cloud Computing, Containerisierung und Microservice -Architekturen, Unterstützung von Docker und Kubernetes; 2) Einführung von JIT -Compilern und Aufzählungsarten zur Verbesserung der Leistung und der Datenverarbeitungseffizienz; 3) die Leistung kontinuierlich optimieren und Best Practices fördern.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

MantisBT

MantisBT

Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor