Menggabungkan Sisipan dan Kemas Kini dalam Prosedur Tersimpan Pelayan SQL
Soalan:
Dalam usaha untuk mengoptimumkan kecekapan, prosedur tersimpan telah dibangunkan yang melaksanakan kemas kini jika rekod wujud dan memasukkan jika ia berlaku bukan. Prosedur tersimpan menggunakan pilihan tersirat dalam pernyataan kemas kini untuk mengendalikan kedua-dua senario. Adakah ini pendekatan yang optimum?
Jawapan:
Logik anda betul, dan ini adalah pendekatan yang sesuai untuk menggabungkan sisipan dan kemas kini dalam prosedur tersimpan, biasanya dikenali sebagai Corak UPSERT atau MERGE.
Rasional di sebalik pendekatan ini ialah ia mengurangkan bilangan bacaan pangkalan data dengan ketara berbanding dengan melaksanakan penyataan pilih berasingan untuk kedua-dua senario. Dengan mencuba kemas kini dahulu dan hanya melakukan sisipan jika tiada baris terjejas, anda meminimumkan operasi I/O pada pangkalan data.
Kepentingan UPSERT:
Seperti yang diserlahkan dalam perbincangan di sqlservercentral.com, UPSERT boleh meningkatkan prestasi dengan ketara dengan menghapuskan berlebihan berbunyi:
"Untuk setiap kemas kini... kami akan mengalih keluar satu bacaan tambahan daripada jadual jika kami menggunakan UPSERT dan bukannya EXISTS."
Pengoptimuman ini amat berfaedah apabila baris berkemungkinan wujud, kerana ia menghapuskan pilihan yang tidak perlu kenyataan.
Pertimbangan:
Adalah penting untuk ambil perhatian bahawa corak ini mungkin tidak selalu menjadi pilihan terbaik. Dalam senario di mana anda sering menemui rekod yang tidak wujud, mungkin lebih cekap untuk melakukan pemilihan eksplisit untuk menyemak kewujudan sebelum mencuba kemas kini.
Selain itu, seperti yang dinyatakan dalam suntingan yang disediakan, mungkin terdapat isu yang berpotensi dengan corak ini berkaitan dengan keadaan konkurensi dan kaum. Adalah disyorkan untuk merujuk sumber tambahan untuk memahami amalan terbaik dan potensi perangkap menggunakan pendekatan ini.
Atas ialah kandungan terperinci Adakah Menggunakan PILIHAN Tersirat dalam Pernyataan KEMASKINI merupakan Pendekatan Optimum untuk Menggabungkan Sisipan dan Kemas Kini Pelayan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!