


Sambungan pangkalan data PHP lanjutan: urus niaga, kunci dan kawalan konkurensi
Jun 01, 2024 am 11:43 AMSambungan pangkalan data PHP lanjutan melibatkan transaksi, kunci dan kawalan serentak untuk memastikan integriti data dan mengelakkan ralat. Transaksi ialah unit atom bagi satu set operasi, diuruskan melalui kaedah beginTransaction(), commit(), dan rollback(). Kunci menghalang akses serentak kepada data melalui PDO::LOCK_SHARED dan PDO::LOCK_EXCLUSIVE. Kawalan konkurensi menyelaraskan akses kepada berbilang transaksi melalui tahap pengasingan MySQL (Baca Tidak Komited, Baca Komited, Bacaan Boleh Ulang, Boleh Bersiri). Dalam aplikasi praktikal, urus niaga, kunci dan kawalan konkurensi digunakan untuk pengurusan inventori produk di tapak web beli-belah untuk memastikan integriti data dan mengelakkan masalah inventori.
Sambungan Pangkalan Data PHP Lanjutan: Transaksi, Kunci dan Kawalan Konkurensi
Apabila berinteraksi dengan pangkalan data menggunakan PHP, memahami konsep lanjutan seperti urus niaga, kunci dan kawalan serentak adalah penting untuk memastikan integriti data dan mengelakkan ralat dalam aplikasi anda penting.
Transaksi
Transaksi ialah koleksi operasi pangkalan data yang dilaksanakan sebagai unit atom. Ini bermakna semua operasi dalam transaksi sama ada semuanya berjaya atau semua gagal.
Gunakan kaedah beginTransaction()
, commit()
dan rollback()
untuk memulakan, melakukan dan melancarkan transaksi: beginTransaction()
、commit()
和 rollback()
方法來(lái)啟動(dòng)、提交和回滾事務(wù):
$db->beginTransaction(); try { // 執(zhí)行數(shù)據(jù)庫(kù)操作 $db->commit(); } catch (\Exception $e) { $db->rollback(); }
鎖
鎖用于防止事務(wù)同時(shí)訪問(wèn)相同的數(shù)據(jù)庫(kù)數(shù)據(jù)。PHP 的 PDO 提供了兩種鎖定模式:
PDO::LOCK_SHARED
:允許事務(wù)讀取數(shù)據(jù),但不能寫(xiě)入。PDO::LOCK_EXCLUSIVE
:允許事務(wù)讀取和寫(xiě)入數(shù)據(jù),但其他事務(wù)無(wú)法同時(shí)訪問(wèn)。
要通過(guò) query()
方法對(duì)表行進(jìn)行鎖定:
$stmt = $db->query('SELECT * FROM table WHERE id = 1 FOR UPDATE');
并發(fā)控制
并發(fā)控制機(jī)制確保當(dāng)多個(gè)事務(wù)同時(shí)訪問(wèn)數(shù)據(jù)庫(kù)時(shí)不會(huì)發(fā)生數(shù)據(jù)沖突。MySQL 提供了以下隔離級(jí)別:
- 讀未提交 (READ UNCOMMITTED):事務(wù)可以讀取其他事務(wù)未提交的數(shù)據(jù)。
- 讀已提交 (READ COMMITTED):事務(wù)只能讀取其他已提交的事務(wù)的數(shù)據(jù)。
- 可重復(fù)讀 (REPEATABLE READ):事務(wù)在整個(gè)生命周期內(nèi)都可以看到其他已提交事務(wù)的數(shù)據(jù),但不能看到未提交的事務(wù)的數(shù)據(jù)。
- 串行化 (SERIALIZABLE):事務(wù)串行執(zhí)行,避免任何并發(fā)沖突。
您可以在連接到數(shù)據(jù)庫(kù)時(shí)通過(guò) PDO::ATTR_DEFAULT_FETCH_MODE
$db->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC); $db->setAttribute(PDO::ATTR_TRANSACTION_ISOLATION, PDO::ISOLATION_READ_COMMITTED);Lock
Kunci digunakan untuk menghalang transaksi daripada mengakses data pangkalan data yang sama pada masa yang sama. PDO PHP menyediakan dua mod penguncian:
PDO::LOCK_SHARED
: membenarkan transaksi membaca data, tetapi tidak menulis.PDO::LOCK_EXCLUSIVE
: Urus niaga dibenarkan untuk membaca dan menulis data, tetapi transaksi lain tidak boleh mengaksesnya pada masa yang sama.
query()
: // 啟動(dòng)事務(wù) $db->beginTransaction(); // 鎖定產(chǎn)品行 $stmt = $db->query('SELECT * FROM products WHERE id = :id FOR UPDATE'); $stmt->bindParam(':id', $productId); $stmt->execute(); // 獲取產(chǎn)品數(shù)量 $product = $stmt->fetch(); $quantity = $product['quantity']; // 檢查庫(kù)存 if ($quantity <= 0) { $db->rollback(); throw new RuntimeException('Product is out of stock.'); } // 更新庫(kù)存 $quantity--; $stmt = $db->prepare('UPDATE products SET quantity = :quantity WHERE id = :id'); $stmt->bindParam(':quantity', $quantity); $stmt->bindParam(':id', $productId); $stmt->execute(); // 提交事務(wù) $db->commit();Concurrency control????Mekanisme kawalan concurrency memastikan ia tidak berlaku apabila berbilang transaksi mengakses pangkalan data pada masa yang sama Konflik data. MySQL menyediakan tahap pengasingan berikut: ??
- BACA TAK KOMITED:Urus niaga boleh membaca data tidak komited daripada transaksi lain.
- MEMBACA KOMITED: Transaksi hanya boleh membaca data daripada urus niaga komited lain.
- BACA DIULANG: Transaksi boleh melihat data transaksi komited lain sepanjang kitaran hayatnya, tetapi tidak dapat melihat data transaksi tidak komited.
- BOLEH SIRI: Urus niaga dilaksanakan secara bersiri untuk mengelakkan sebarang konflik serentak.
PDO::ATTR_DEFAULT_FETCH_MODE
apabila menyambung ke pangkalan data: ??rrreee??Kes praktikal????Pertimbangkan tapak web beli-belah dalam talian di mana pengguna boleh Tambahkan produk ke troli dan beli. Untuk mengelakkan masalah, seperti produk yang sama ditambahkan pada troli beli-belah oleh berbilang pengguna pada masa yang sama, urus niaga, kunci dan kawalan serentak boleh digunakan untuk memastikan integriti data: ??rrreee?? Dengan menggunakan transaksi, kunci dan kawalan konkurensi , kami boleh memastikan integriti Pangkalan Data pengguna semasa membeli produk dan mengelakkan sebarang isu inventori. ??Atas ialah kandungan terperinci Sambungan pangkalan data PHP lanjutan: urus niaga, kunci dan kawalan konkurensi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tostaycurrentwithphpdevelopmentsandbestpractices, followeyNewsssourcesLikePhp.netandphpweekly, engageWithCommunitiesonforumsandconference, keeptoolingupdatedandgraduallyAdoptNewFeatures, dan readribcoursourcourceSource

Phpbecamepopularforwebdevelopmentduetoitseaseoflearning, seamlessintegrationwithhtml, widespreadhostingsupport, andalargeecosystemincludingframeworkslikelaravelandcmsplatformsLikeWordPress.itexcelsinhandessubmissions

TosetTheRightTimeZoneinPhp, USEDATE_DEFAULT_TIMEZONE_SET () functionAtthestArtAfyourscriptwithavalididentifiersuchas'america/new_york'.1.usedate_default_timeSet ()

TOVALIDATEUSERIputInphp, UsEbuilt-InvalidationFunctionsLikeFilter_var () danFilter_Input (), applyRegularExpressionsforcustomformatssuchasususerorphonenumbers, checkdatatypesfornumericressplimeSpriceSprice, setLengthacheAngeAgeorpriceSprice, setLengthacheArpesenprice,

ThPhpFunctionserialize () andUnserialize () diselaraskanToConvertComplexDataStructructDestoresIntoStorasandabackagain.1.Serialize () C overtsdatalikeCarraysorObjectSrayStringContainingTyPeanStructureStructureStructureStructure.2.2Serialize ()

Anda boleh membenamkan kod PHP ke dalam fail HTML, tetapi pastikan fail itu mempunyai lanjutan .php supaya pelayan dapat menghuraikannya dengan betul. Gunakan tag standard untuk membungkus kod PHP, masukkan kandungan dinamik di mana sahaja di HTML. Di samping itu, anda boleh menukar PHP dan HTML beberapa kali dalam fail yang sama untuk merealisasikan fungsi dinamik seperti rendering bersyarat. Pastikan anda memberi perhatian kepada konfigurasi pelayan dan ketepatan sintaks untuk mengelakkan masalah yang disebabkan oleh label pendek, kesilapan tanda petikan atau label akhir yang ditinggalkan.

Kunci untuk menulis kod PHP yang bersih dan mudah dijaga terletak pada penamaan yang jelas, berikutan piawaian, struktur yang munasabah, menggunakan komen dan kesesuaian yang baik. 1. Gunakan pembolehubah, fungsi dan nama kelas yang jelas, seperti $ userData dan calculateToTalPrice (); 2. Ikuti gaya kod bersatu piawai PSR-12; 3. Pecahkan struktur kod mengikut tanggungjawab, dan aturnya menggunakan katalog MVC atau Laravel; 4. Elakkan kod gaya mi dan memecah logik ke dalam fungsi kecil dengan satu tanggungjawab; 5. Tambah komen pada mata utama dan tulis dokumen antara muka untuk menjelaskan parameter, pulangan nilai dan pengecualian; 6. Meningkatkan kebolehlihatan, mengguna pakai suntikan pergantungan, mengurangkan kaedah keadaan global dan statik. Amalan ini meningkatkan kualiti kod, kecekapan kerjasama dan kemudahan pasca penyelenggaraan.

Ya, youpanrunsqlqueriesusingphp, danTheProcessinvolveschoosingadatabaseextension, connectingTothedatabase, executingqueriSafely, andclosingconnectionswhendone.todothis, firstChoosebetweBetbeSquLiorpiorpiorpiorpiorpiorpiorpiorpiorpiorpiorpiorpiorpiorpiorpiorpiorpiorpiorpiorpdob
