Rumah >pembangunan bahagian belakang >tutorial php >Apakah Pendekatan Optimum untuk Mendapatkan Kiraan Baris dengan PDO dalam PHP?

Apakah Pendekatan Optimum untuk Mendapatkan Kiraan Baris dengan PDO dalam PHP?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-12-23 19:39:21390semak imbas

What's the Optimal Approach to Getting a Row Count with PDO in PHP?

Pengiraan Baris dengan PDO: Pendekatan Optimum

Mendapatkan kiraan baris menggunakan PDO dalam PHP boleh dicapai melalui pelbagai kaedah. Walau bagaimanapun, pendekatan terbaik bergantung pada kes penggunaan khusus anda dan pertimbangan saiz data.

Jika anda hanya memerlukan kiraan baris dan bukan data itu sendiri, menggunakan pertanyaan "SELECT count(*)" adalah disyorkan. Berikut ialah contoh kod:

$sql = "SELECT count(*) FROM `table` WHERE foo = ?";
$result = $con->prepare($sql);
$result->execute([$bar]);
$number_of_rows = $result->fetchColumn();

Untuk senario di mana anda memerlukan bilangan baris bersama-sama dengan data yang diambil, PDO menyediakan kaedah PDOStatement::rowCount(). Walau bagaimanapun, kebolehpercayaannya merentas pemandu yang berbeza tidak dijamin. Seperti dalam dokumentasi PDO:

"Untuk kebanyakan pangkalan data, PDOStatement::rowCount() tidak mengembalikan bilangan baris yang dipengaruhi oleh pernyataan SELECT... Sebaliknya, gunakan PDO::query() untuk mengeluarkan SELECT COUNT(*) statement... kemudian gunakan PDOStatement::fetchColumn() untuk mendapatkan semula bilangan baris yang akan dikembalikan."

Dalam kes sedemikian, anda boleh menggunakan fungsi PDO::fetchAll() untuk mendapatkan semula data ke dalam tatasusunan dan kemudian menggunakan count() untuk menentukan bilangan baris.

$data = $pdo->fetchAll();
$number_of_rows = count($data);

Sebagai alternatif, jika pertanyaan anda mudah dan tidak menggunakan pembolehubah, anda boleh menggunakan fungsi query() secara langsung:

$nRows = $pdo->query('select count(*) from blah')->fetchColumn();
echo $nRows;

Atas ialah kandungan terperinci Apakah Pendekatan Optimum untuk Mendapatkan Kiraan Baris dengan PDO dalam PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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