国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Jadual Kandungan
Sambungan Pangkalan Data PHP Lanjutan: Transaksi, Kunci dan Kawalan Konkurensi
Transaksi
并發(fā)控制
Rumah pembangunan bahagian belakang tutorial php Sambungan pangkalan data PHP lanjutan: urus niaga, kunci dan kawalan konkurensi

Sambungan pangkalan data PHP lanjutan: urus niaga, kunci dan kawalan konkurensi

Jun 01, 2024 am 11:43 AM
php Sambungan pangkalan data

Sambungan 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.

高級(jí) PHP 數(shù)據(jù)庫(kù)連接:事務(wù)、鎖和并發(fā)控制

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.

Untuk mengunci baris jadual melalui kaedah 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.
??Anda boleh menetapkan tahap pengasingan melalui pilihan 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!

Kenyataan Laman Web ini
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

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimanakah saya tetap terkini dengan perkembangan php terkini dan amalan terbaik? Bagaimanakah saya tetap terkini dengan perkembangan php terkini dan amalan terbaik? Jun 23, 2025 am 12:56 AM

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

Apakah php, dan mengapa ia digunakan untuk pembangunan web? Apakah php, dan mengapa ia digunakan untuk pembangunan web? Jun 23, 2025 am 12:55 AM

Phpbecamepopularforwebdevelopmentduetoitseaseoflearning, seamlessintegrationwithhtml, widespreadhostingsupport, andalargeecosystemincludingframeworkslikelaravelandcmsplatformsLikeWordPress.itexcelsinhandessubmissions

Bagaimana cara menetapkan zon waktu php? Bagaimana cara menetapkan zon waktu php? Jun 25, 2025 am 01:00 AM

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

Bagaimanakah saya mengesahkan input pengguna dalam PHP untuk memastikan ia memenuhi kriteria tertentu? Bagaimanakah saya mengesahkan input pengguna dalam PHP untuk memastikan ia memenuhi kriteria tertentu? Jun 22, 2025 am 01:00 AM

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

Apakah Serialization Data dalam PHP (Serialize (), Unserialize ())? Apakah Serialization Data dalam PHP (Serialize (), Unserialize ())? Jun 22, 2025 am 01:03 AM

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

Bagaimana saya membenamkan kod php dalam fail html? Bagaimana saya membenamkan kod php dalam fail html? Jun 22, 2025 am 01:00 AM

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.

Apakah amalan terbaik untuk menulis kod PHP yang bersih dan boleh dipelihara? Apakah amalan terbaik untuk menulis kod PHP yang bersih dan boleh dipelihara? Jun 24, 2025 am 12:53 AM

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.

Bagaimana saya melaksanakan pertanyaan SQL menggunakan php? Bagaimana saya melaksanakan pertanyaan SQL menggunakan php? Jun 24, 2025 am 12:54 AM

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

See all articles