UBAH JADUAL Tanpa Mengunci Jadual
Apabila menjalankan operasi ALTER TABLE dalam MySQL, jadual dikunci baca untuk tempoh kenyataan, berpotensi menyekat penulisan serentak. Jika operasi ini dilakukan pada jadual besar, penyataan INSERT atau UPDATE boleh terganggu untuk tempoh yang panjang. Adakah terdapat penyelesaian untuk melakukan "ubah panas" tanpa menjejaskan kemas kini yang berterusan?
Satu-satunya Alternatif: Manipulasi Manual
Walaupun MySQL tidak mempunyai sokongan langsung untuk pengubah panas, alternatif wujud: secara manual mereplikasi fungsi yang banyak sistem RDBMS lakukan secara automatik. Ini melibatkan:
Pertimbangan Teknikal:
Menambah medan baharu mengubah suai setiap baris dalam jadual dengan berkesan. Proses ini memerlukan penstrukturan semula fizikal data pada cakera, serupa dengan operasi KEMASKINI yang meluas dengan impak yang lebih besar. Penguncian peringkat medan akan menjadi lebih kompleks daripada penguncian peringkat baris, dan kunci seluruh meja tidak selalu diingini.
Penyelesaian RDBMS Lain:
Walaupun MySQL mungkin tidak menyokong perubahan panas secara asli, sistem RDBMS lain mungkin menawarkan fungsi sedemikian. Sebagai contoh, PostgreSQL membenarkan jadual pembahagian, yang boleh diubah secara individu tanpa menjejaskan partition lain.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaksanakan Operasi `ALTER TABLE` MySQL Tanpa Mengunci Jadual dan Mengganggu Kemas Kini Serentak?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!