Rumah >pangkalan data >tutorial mysql >INSERT Tunggal dengan Berbilang Nilai lwn. Berbilang Sisipan: Bilakah Pengumpulan Menjadi Bottleneck?
Sisipan kelompok dan sisipan tunggal berbilang nilai: Bilakah pemprosesan kelompok menjadi halangan?
Perbandingan prestasi yang mengejutkan menunjukkan bahawa melaksanakan 1000 pernyataan INSERT sahaja (290 milisaat) menunjukkan prestasi yang lebih baik daripada memasukkan 1000 nilai menggunakan satu pernyataan INSERT (2800 milisaat). Untuk menyiasat keputusan yang tidak dijangka ini, mari kita menganalisis rancangan pelaksanaan dan mengenal pasti kemungkinan kesesakan.
Pemeriksaan pelan pelaksanaan menunjukkan bahawa pernyataan INSERT tunggal menggunakan proses parameterisasi automatik untuk meminimumkan masa menghurai/menghimpun. Walau bagaimanapun, masa penyusunan pernyataan INSERT tunggal tiba-tiba meningkat pada kira-kira 250 klausa nilai, menyebabkan saiz pelan cache berkurangan dan masa penyusunan meningkat.
Analisis lanjut menunjukkan bahawa apabila menyusun rancangan untuk nilai literal tertentu, SQL Server mungkin melakukan beberapa aktiviti yang tidak berskala secara linear, seperti pengisihan. Walaupun tanpa mengisih pada masa penyusunan, menambah indeks berkelompok pada jadual akan menunjukkan langkah pengisihan eksplisit dalam pelan.
Semasa fasa penyusunan, surih tindanan proses SQL Server menunjukkan bahawa banyak masa dihabiskan untuk membandingkan rentetan. Ini mungkin berkaitan dengan fasa normalisasi (mengikat atau algebra) pemprosesan pertanyaan, di mana pepohon parse ungkapan ditukar kepada pepohon ungkapan algebra.
Percubaan yang memvariasikan panjang dan keunikan rentetan yang disisipkan telah menunjukkan bahawa rentetan yang lebih panjang dan lebih sedikit pendua mengakibatkan prestasi masa kompilasi yang lebih teruk. Ini menunjukkan bahawa SQL Server menghabiskan lebih banyak masa untuk membandingkan dan mengenal pasti pendua semasa penyusunan.
Dalam sesetengah kes, tingkah laku ini boleh dieksploitasi untuk meningkatkan prestasi. Sebagai contoh, dalam pertanyaan yang menggunakan lajur bebas pendua sebagai kunci isihan utama, SQL Server boleh melangkau pengisihan mengikut kekunci kedua pada masa jalan dan mengelakkan ralat bahagi dengan sifar.
Jadi semasa memasukkan berbilang nilai menggunakan satu pernyataan INSERT mungkin kelihatan lebih pantas daripada berbilang pernyataan INSERT, overhed masa penyusunan yang dikaitkan dengan pemprosesan sejumlah besar nilai berbeza (terutama rentetan panjang) boleh menyebabkan kemerosotan prestasi yang ketara dalam Penolakan SQL Server.
Atas ialah kandungan terperinci INSERT Tunggal dengan Berbilang Nilai lwn. Berbilang Sisipan: Bilakah Pengumpulan Menjadi Bottleneck?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!