Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk menulis transaksi pangkalan data dalam PHP

Bagaimana untuk menulis transaksi pangkalan data dalam PHP

WBOY
WBOYasal
2023-05-16 08:45:211472semak imbas

PHP ialah bahasa pembangunan Web yang digunakan secara meluas Oleh kerana kesederhanaan, kemudahan pembelajaran, fleksibiliti dan kelajuan yang pantas, ia telah menjadi alat penting dalam bidang pembangunan Web. Dalam pembangunan web, pangkalan data adalah salah satu komponen yang sangat diperlukan. Untuk memastikan integriti dan konsistensi pangkalan data, pembangun boleh menggunakan transaksi untuk mengawal operasi pangkalan data. Artikel ini akan memperkenalkan cara menulis transaksi pangkalan data menggunakan PHP.

1. Apakah itu transaksi pangkalan data?

Transaksi Pangkalan Data merujuk kepada satu set operasi pangkalan data yang boleh diproses sebagai satu unit kerja logik dan memenuhi empat ciri berikut (ACID):

  1. Atomisitas Atom: Transaksi adalah unit operasi tidak boleh dibahagikan yang mesti diselesaikan atau digulung semula.
  2. Ketekalan: Keadaan pangkalan data harus kekal konsisten sebelum dan selepas pelaksanaan transaksi.
  3. Pengasingan: Pengubahsuaian semasa pelaksanaan transaksi tidak kelihatan kepada transaksi lain.
  4. Ketahanan: Selepas transaksi berjaya dilaksanakan, pengubahsuaian pada pangkalan data perlu disimpan secara kekal dan tidak akan hilang walaupun sistem gagal.

2. Bagaimanakah PHP melaksanakan transaksi pangkalan data?

Menggunakan PHP untuk melaksanakan transaksi pangkalan data memerlukan penggunaan sambungan operasi pangkalan data, seperti MySQLi, PDO, dsb. Berikut menggunakan MySQLi sebagai contoh untuk memperkenalkan cara melaksanakan transaksi pangkalan data.

  1. Mulakan Transaksi

Sebelum menggunakan MySQLi untuk operasi pangkalan data, anda perlu mencipta sambungan MySQL. Selepas sambungan dibuat, anda boleh menggunakan fungsi mysqli_begin_transaction() untuk memulakan transaksi baharu. Kod sampel adalah seperti berikut:

$mysqli = new mysqli("localhost", "username", "password", "database");
$mysqli->begin_transaction();
  1. Lakukan operasi

Selepas memulakan transaksi, anda boleh melakukan operasi pangkalan data seperti memasukkan, mengemas kini, memadam data, dsb. Kod sampel adalah seperti berikut:

$mysqli->query("INSERT INTO `user` (`name`, `age`, `sex`) VALUES ('张三', 20, 1)");
$mysqli->query("UPDATE `user` SET `age` = 21 WHERE `name` = '张三'");
$mysqli->query("DELETE FROM `user` WHERE `name` = '李四'");
  1. Komit atau tarik balik transaksi

Selepas operasi transaksi selesai, anda boleh menggunakan fungsi mysqli_commit() untuk melakukan transaksi dan gunakan semua operasi ke tengah pangkalan data. Jika ralat berlaku atau anda ingin melancarkan operasi, anda boleh menggunakan fungsi mysqli_rollback() untuk melaksanakan rollback transaksi. Kod sampel adalah seperti berikut:

try {
    $mysqli->commit();
    echo "操作成功";
} catch (Exception $e) {
    $mysqli_rollback();
    echo "操作失败";
}

Dalam kod di atas, jika semua operasi dilaksanakan dengan jayanya, urus niaga dilakukan dan "operasi berjaya" akan dikeluarkan, jika tidak, urus niaga akan ditarik balik dan "operasi gagal" adalah keluaran.

3. Langkah berjaga-jaga untuk digunakan

  1. Semua operasi pangkalan data mesti dilakukan antara permulaan urus niaga dan commit atau rollback.
  2. Semasa proses pelaksanaan urus niaga, jika ralat berlaku, urus niaga mesti digulung semula dalam masa untuk mengelakkan kerosakan tidak dapat dipulihkan pada pangkalan data.
  3. Di mana sahaja pernyataan yang disediakan boleh digunakan, cuba gunakan pernyataan yang disediakan untuk mengelakkan risiko suntikan SQL.
  4. Setiap sambungan pangkalan data hanya boleh menjalankan satu transaksi pada masa yang sama dan berbilang transaksi memerlukan berbilang sambungan.
  5. Apabila menggunakan transaksi pangkalan data, anda mesti memastikan semua jadual menggunakan enjin storan InnoDB, kerana InnoDB menyokong transaksi, tetapi MyISAM tidak menyokong transaksi.

4. Ringkasan

Menggunakan PHP untuk melaksanakan transaksi pangkalan data dengan berkesan boleh memastikan ketekalan dan integriti operasi pangkalan data dan mengelakkan kesan buruk pada pangkalan data. Pembangun boleh menggunakan operasi transaksi secara rasional berdasarkan keperluan perniagaan khusus untuk meningkatkan kecekapan dan kestabilan pembangunan aplikasi.

Atas ialah kandungan terperinci Bagaimana untuk menulis transaksi pangkalan data dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn