Aktueller Standort: Startseite> Neueste Artikel> Wie kann ich MySQLI :: begin_transaction korrekt verwenden, um die Datenbank -Transaktionsregelung zu implementieren?

Wie kann ich MySQLI :: begin_transaction korrekt verwenden, um die Datenbank -Transaktionsregelung zu implementieren?

gitbox 2025-08-21

<span><span><span class="hljs-meta"><?php</span></span><span> </span><span><span class="hljs-comment">// 本段是与文章内容无关的部分</span></span><span> </span><span><span class="hljs-comment">// 例如可以是作者信息、版权声明或加载某些配置</span></span><span> </span><span><span class="hljs-title function_ invoke__">date_default_timezone_set</span></span><span>(</span><span><span class="hljs-string">'Asia/Shanghai'</span></span><span>); </span><span><span class="hljs-variable">$author</span></span><span> = </span><span><span class="hljs-string">"数据库事务研究小组"</span></span><span>; </span><span><span class="hljs-variable">$publish_date</span></span><span> = </span><span><span class="hljs-title function_ invoke__">date</span></span><span>(</span><span><span class="hljs-string">'Y-m-d'</span></span><span>); </span><span><span class="hljs-meta">?></span></span><span> <hr> <h1>如何正确使用 mysqli::</span><span><span class="hljs-variable constant_">begin_transaction</span></span><span> 来实现数据库事务控制?</h1> <p>在使用 MySQL 数据库进行开发时,事务控制是保障数据一致性与完整性的重要手段。PHP 的 <code>mysqli

  • : Optional, Geben Sie das Transaktionsverhalten wie MySQLI_TRANS_START_READ_ONLY oder MYSQLI_TRANS_START_READ_WRITE an.
  • $ Name : Optional, zuweisen Sie der Transaktion einen Namen (hauptsächlich in XA -Transaktionen oder bestimmten erweiterten Szenarien).

1. Grundlegende Beispiele
 
</span><span><span class="hljs-variable">$mysqli</span></span><span> = </span><span><span class="hljs-keyword">new</span></span><span> </span><span><span class="hljs-title function_ invoke__">mysqli</span></span><span>(</span><span><span class="hljs-string">'localhost'</span></span><span>, </span><span><span class="hljs-string">'user'</span></span><span>, </span><span><span class="hljs-string">'password'</span></span><span>, </span><span><span class="hljs-string">'testdb'</span></span><span>);

</span><span><span class="hljs-keyword">if</span></span><span> (</span><span><span class="hljs-variable">$mysqli</span></span><span>->connect_errno) {
    </span><span><span class="hljs-keyword">die</span></span><span>(</span><span><span class="hljs-string">'Verbindung ist fehlgeschlagen: '</span></span><span> . </span><span><span class="hljs-variable">$mysqli</span></span><span>->connect_error);
}

</span><span><span class="hljs-keyword">try</span></span><span> {
    </span><span><span class="hljs-comment">// Explizit Transaktionen aktivieren</span></span><span>
    </span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">begin_transaction</span></span><span>();

    </span><span><span class="hljs-comment">// Führen Sie mehrere verwandte Elemente aus SQL Stellungnahme</span></span><span>
    </span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">query</span></span><span>(</span><span><span class="hljs-string">"UPDATE accounts SET balance = balance - 100 WHERE id = 1"</span></span><span>);
    </span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">query</span></span><span>(</span><span><span class="hljs-string">"UPDATE accounts SET balance = balance + 100 WHERE id = 2"</span></span><span>);

    </span><span><span class="hljs-comment">// Transaktionen einreichen</span></span><span>
    </span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">commit</span></span><span>();
    </span><span><span class="hljs-keyword">echo</span></span><span> </span><span><span class="hljs-string">"Erfolgreich übertragen"</span></span><span>;
} </span><span><span class="hljs-keyword">catch</span></span><span> (</span><span><span class="hljs-built_in">Exception</span></span><span> </span><span><span class="hljs-variable">$e</span></span><span>) {
    </span><span><span class="hljs-comment">// Rollen Sie zurück, wenn ein Fehler auftritt</span></span><span>
    </span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">rollback</span></span><span>();
    </span><span><span class="hljs-keyword">echo</span></span><span> </span><span><span class="hljs-string">"Übertragung fehlgeschlagen: "</span></span><span> . </span><span><span class="hljs-variable">$e</span></span><span>-></span><span><span class="hljs-title function_ invoke__">getMessage</span></span><span>();
}

</span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">close</span></span><span>();

4.. Dinge zu beachten
  • Stellen Sie sicher, dass AutoCommit ausgeschaltet ist ( begin_Transaction wird automatisch den Autokommit -Modus der aktuellen Sitzung ausschalten).
  • Gehen Sie immer Transaktionen im Versuch ab, um sicherzustellen, dass Fehler zurückgerollt werden können.
  • Verwenden Sie in hohen Parallelitätsumgebungen Schlösser und Isolationsstufen vernünftigerweise (können über eingestellte Transaktions -Isolationsebene festgelegt werden).

5. Zusammenfassung

Durch die Verwendung von MySQLI :: Beginn_Transaction können PHP -Entwickler Transaktionsprozesse intuitiver und kontrollierbarer verwalten. In den tatsächlichen Projekten ist es wichtig, Transaktionen bei der Ausführung mehrerer logischbezogener Datenbankvorgänge zu verwenden und eine gute Aufgabe des Fehlerbehebung und der Rollback-Logik, um die Konsistenz und Sicherheit der Daten zu gewährleisten.