PSD-Tutorials.de
Forum für Design, Fotografie & Bildbearbeitung
Tutkit
Agentur
Hilfe
Kontakt
Start
Forum
Aktuelles
Besonderer Inhalt
Foren durchsuchen
Tutorials
News
Anmelden
Kostenlos registrieren
Aktuelles
Suche
Suche
Nur Titel durchsuchen
Von:
Menü
Anmelden
Kostenlos registrieren
App installieren
Installieren
JavaScript ist deaktiviert. Für eine bessere Darstellung aktiviere bitte JavaScript in deinem Browser, bevor du fortfährst.
Du verwendest einen veralteten Browser. Es ist möglich, dass diese oder andere Websites nicht korrekt angezeigt werden.
Du solltest ein Upgrade durchführen oder einen
alternativen Browser
verwenden.
Antworten auf deine Fragen:
Neues Thema erstellen
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
InnoDB - Transactions -> funktioniert nicht richtig
Beitrag
<blockquote data-quote="d3mueller" data-source="post: 2353459" data-attributes="member: 568927"><p>Hi,</p><p></p><p>ich versuche gerade mit der innoDB-Engine und Transactions klar zu kommen. Eigentlich soll das ja unter anderem verhindern, dass gleichzeitige Zugriffe auf die Datenbank verhindert werden, um so Datenverfälschung und so zu verhindern.</p><p></p><p>Also Skript A hat eine Transaktion gestartet, die z.B. 2 Sekunden dauert.</p><p></p><p>Aber nach einer Sekunde greift Skript B auch auf die Datenbank zu und will z.B. was auslesen. Eigentlich müsste Skript B doch jetzt warten, bis Skript A fertig ist, oder nicht? Bei mir funktioniert das nicht:</p><p></p><p>Skript A:</p><p></p><p>[PHP]</p><p>$db->query("SET AUTOCOMMIT = 0;");</p><p>$db->query("START TRANSACTION;");</p><p>try {</p><p> $i = 200;</p><p> while ($i <= 700) {</p><p> // Damit das Skript auch ne Weile läuft, hab ich hier die Schleife eingebaut</p><p> var_dump($db->query("INSERT INTO test VALUES ({$i}, 'testvalue')"));</p><p> $i++;</p><p> }</p><p> $db->query("COMMIT;");</p><p>}</p><p>catch (Exception $e) {</p><p> $db->query("ROLLBACK;");</p><p> echo $e->getMessage();</p><p>}</p><p>[/PHP]</p><p></p><p>Skript B:</p><p></p><p>[PHP]</p><p>$db->query("SET AUTOCOMMIT = 0;");</p><p>$db->query("START TRANSACTION;");</p><p></p><p>try {</p><p> // Das hier gibt mir einfach ein Array mit den Daten zurück, die mit var_dump ausgegeben werden</p><p> var_dump($db->query("SELECT * FROM test", "assoc"));</p><p> $db->query("COMMIT;");</p><p>}</p><p>catch (Exception $e) {</p><p> $db->query("ROLLBACK");</p><p> echo $e->getMessage();</p><p>}</p><p>[/PHP]</p><p></p><p>Das $db->query() führt einfach das SQL aus, das funktioniert auch. Die Datenbanktabelle läuft auch mit der InnoDB-Engine (hab es zumindest ausgwählt beim erstellen)</p><p></p><p></p><p>Wenn ich jetzt die Seite mit Skript A starte und dann ganz schnell (mit meinem Laptop) die andere Seite mit Skript B starte, dann läuft Skript A ja noch.</p><p></p><p>Jetzt gibt mir Skript B aber nicht die 501 Einträge aus, sondern nur um die 70 Stück, weil Skript A noch nicht fertig war, als ich Skript B aufgerufen habe.</p><p></p><p>Aber eigentlich sollen doch Transactions genau das verhindern, oder? Das Skript B warten muss, bis Skript A komplett fertig ist.</p><p></p><p>Habe ich einen Fehler im Code? Oder in meinem Verständnis von Transactions?</p><p></p><p>Danke schon mal</p><p></p><p>LG</p></blockquote><p></p>
[QUOTE="d3mueller, post: 2353459, member: 568927"] Hi, ich versuche gerade mit der innoDB-Engine und Transactions klar zu kommen. Eigentlich soll das ja unter anderem verhindern, dass gleichzeitige Zugriffe auf die Datenbank verhindert werden, um so Datenverfälschung und so zu verhindern. Also Skript A hat eine Transaktion gestartet, die z.B. 2 Sekunden dauert. Aber nach einer Sekunde greift Skript B auch auf die Datenbank zu und will z.B. was auslesen. Eigentlich müsste Skript B doch jetzt warten, bis Skript A fertig ist, oder nicht? Bei mir funktioniert das nicht: Skript A: [PHP] $db->query("SET AUTOCOMMIT = 0;"); $db->query("START TRANSACTION;"); try { $i = 200; while ($i <= 700) { // Damit das Skript auch ne Weile läuft, hab ich hier die Schleife eingebaut var_dump($db->query("INSERT INTO test VALUES ({$i}, 'testvalue')")); $i++; } $db->query("COMMIT;"); } catch (Exception $e) { $db->query("ROLLBACK;"); echo $e->getMessage(); } [/PHP] Skript B: [PHP] $db->query("SET AUTOCOMMIT = 0;"); $db->query("START TRANSACTION;"); try { // Das hier gibt mir einfach ein Array mit den Daten zurück, die mit var_dump ausgegeben werden var_dump($db->query("SELECT * FROM test", "assoc")); $db->query("COMMIT;"); } catch (Exception $e) { $db->query("ROLLBACK"); echo $e->getMessage(); } [/PHP] Das $db->query() führt einfach das SQL aus, das funktioniert auch. Die Datenbanktabelle läuft auch mit der InnoDB-Engine (hab es zumindest ausgwählt beim erstellen) Wenn ich jetzt die Seite mit Skript A starte und dann ganz schnell (mit meinem Laptop) die andere Seite mit Skript B starte, dann läuft Skript A ja noch. Jetzt gibt mir Skript B aber nicht die 501 Einträge aus, sondern nur um die 70 Stück, weil Skript A noch nicht fertig war, als ich Skript B aufgerufen habe. Aber eigentlich sollen doch Transactions genau das verhindern, oder? Das Skript B warten muss, bis Skript A komplett fertig ist. Habe ich einen Fehler im Code? Oder in meinem Verständnis von Transactions? Danke schon mal LG [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ▲ = 5, ▼ = 2 und ■ = 7, was ist ▲ × ▼ + ■?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
InnoDB - Transactions -> funktioniert nicht richtig
Oben