Manakah Lebih Berprestasi: PDO::rowCount() atau COUNT(*) Dengan atau Tanpa Indeks?

Barbara Streisand
Lepaskan: 2024-10-24 07:14:02
asal
353 orang telah melayarinya

Which is More Performant: PDO::rowCount() or COUNT(*) With or Without an Index?

PDO::rowCount vs. COUNT(*) Perbandingan Prestasi

Soalan:

Yang manakah berprestasi lebih baik dalam pertanyaan SELECT dengan semakan kiraan baris: menggunakan PDO::rowCount() atau memasukkan COUNT(*) dalam pertanyaan? Selain itu, pilihan manakah yang lebih cekap apabila indeks ditetapkan pada medan id?

Jawapan:

Soalan Pertama: Count(*) vs. PDO ::rowCount()

Secara dalaman, COUNT() dalam MySQL memperuntukkan memori minimum untuk menyimpan hasil kiraan sahaja, manakala PHP memproses keseluruhan keputusan yang ditetapkan dalam PDO::rowCount(), memperuntukkan memori untuk semua keputusan yang diambil. Oleh itu, COUNT() adalah lebih pantas dalam MySQL.

Soalan Kedua: COUNT(id) lwn. COUNT(*) dengan Indeks

COUNT() ialah diutamakan berbanding COUNT(id) walaupun apabila indeks ditetapkan pada medan id. Ini kerana COUNT() dioptimumkan untuk mengira nilai dengan cepat, mengurangkan keperluan untuk mengambil setiap baris, manakala COUNT(id) memerlukan akses setiap baris, yang berpotensi menurunkan prestasi.

Atas ialah kandungan terperinci Manakah Lebih Berprestasi: PDO::rowCount() atau COUNT(*) Dengan atau Tanpa Indeks?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber: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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!