


Bagaimana untuk menukar objek hasil php kepada array
Dalam PHP, kami sering menggunakan pangkalan data untuk penyimpanan data dan operasi mendapatkan semula. Apabila kami mendapatkan semula data daripada pangkalan data, kami selalunya perlu menukar objek hasil menjadi tatasusunan untuk pemprosesan, paparan atau pemindahan yang mudah kepada atur cara lain untuk diproses. Artikel ini akan memperkenalkan anda cara menukar objek hasil menjadi tatasusunan dalam PHP.
Pertama sekali, kita perlu menjelaskan dengan jelas bahawa objek hasil dalam PHP selalunya jenis PDOStatement atau mysqli_result. Kelas ini menyediakan satu siri kaedah untuk mendapatkan data hasil pertanyaan. Walau bagaimanapun, jika anda menggunakan kaedah ini untuk mendapatkan hasil secara langsung, data yang dikembalikan selalunya merupakan objek, yang menyusahkan untuk diproses. Oleh itu, kita perlu menukar objek hasil ke dalam tatasusunan.
Kaedah 1. Gunakan kaedah fetchAll() dalam PDO
Apabila menggunakan PDO untuk pertanyaan pangkalan data, kita boleh menggunakan kaedah fetchAll() untuk mendapatkan hasil pertanyaan. Kaedah ini mengembalikan tatasusunan dua dimensi yang mengandungi hasil pertanyaan. Hantar tatasusunan kepada fungsi json_encode() untuk menukarnya kepada format JSON dan hantarkannya ke hujung hadapan untuk paparan atau operasi.
Sebagai contoh, contoh kod berikut menunjukkan cara menggunakan kaedah fetchAll() dalam PDO untuk menukar objek hasil menjadi tatasusunan:
$stmt = $pdo->query('SELECT * FROM users'); $result = $stmt->fetchAll(PDO::FETCH_ASSOC); echo json_encode($result);
Kaedah 2. Gunakan fetch_all() kaedah dalam mysqli
Apabila menggunakan mysqli untuk pertanyaan pangkalan data, kita boleh menggunakan kaedah fetch_all() untuk mendapatkan hasil pertanyaan. Kaedah ini mengembalikan tatasusunan dua dimensi yang mengandungi hasil pertanyaan. Begitu juga, hantar tatasusunan kepada fungsi json_encode() untuk menukarnya kepada format JSON dan hantarkannya ke hujung hadapan untuk paparan atau operasi.
Sebagai contoh, contoh kod berikut menunjukkan cara menggunakan kaedah fetch_all() dalam mysqli untuk menukar objek hasil menjadi tatasusunan:
$result = $mysqli->query('SELECT * FROM users')->fetch_all(MYSQLI_ASSOC); echo json_encode($result);
Kaedah 3. Lelaran secara manual melalui hasil objek dan tukar setiap baris Tukar data kepada tatasusunan
Selain daripada dua kaedah di atas, kami juga boleh melelaran secara manual melalui objek hasil dan menukar setiap baris data kepada tatasusunan. Kaedah ini agak menyusahkan, tetapi mungkin membantu untuk beberapa keperluan khas.
Berikut ialah kod sampel yang berulang secara manual melalui objek hasil dan menukar setiap baris data kepada tatasusunan:
$stmt = $pdo->query('SELECT * FROM users'); $result = array(); while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) { $result[] = $row; } echo json_encode($result);
Ringkasan
Di atas ialah cara untuk menukar objek hasil kepada tatasusunan Tiga kaedah. Antaranya, menggunakan kaedah fetchAll() atau fetch_all() ialah kaedah yang paling biasa dan mudah. Perlu diingat bahawa menggunakan kaedah fetchAll() atau fetch_all() boleh memuatkan semua hasil ke dalam memori sekaligus, yang boleh menyebabkan ingatan tidak mencukupi jika set hasil adalah besar. Oleh itu, apabila memproses set hasil yang besar, kita boleh menggunakan paging dan kaedah lain untuk mengurangkan penggunaan memori.
Atas ialah kandungan terperinci Bagaimana untuk menukar objek hasil php kepada array. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Artikel ini meneroka deduplikasi array PHP yang cekap. Ia membandingkan fungsi terbina dalam seperti array_unique () dengan pendekatan hashmap tersuai, menonjolkan prestasi perdagangan berdasarkan saiz array dan jenis data. Kaedah optimum bergantung pada profili

Artikel ini menganalisis PHP Array Deduplication, menonjolkan kemunculan prestasi pendekatan naif (O (N²)). Ia meneroka alternatif yang cekap menggunakan array_unique () dengan fungsi tersuai, splobjectstorage, dan pelaksanaan hashset, mencapai

Artikel ini meneroka deduplikasi PHP Array menggunakan keunikan utama. Walaupun bukan kaedah penyingkiran pendua langsung, memanfaatkan keunikan utama membolehkan membuat array baru dengan nilai yang unik dengan nilai pemetaan ke kekunci, menimpa duplikat. AP ini

Butiran artikel ini melaksanakan beratur mesej dalam PHP menggunakan RabbitMQ dan Redis. Ia membandingkan seni bina mereka (AMQP vs dalam memori), ciri-ciri, dan mekanisme kebolehpercayaan (pengesahan, urus niaga, kegigihan). Amalan terbaik untuk reka bentuk, kesilapan

Artikel ini mengkaji piawaian pengekodan PHP semasa dan amalan terbaik, memberi tumpuan kepada cadangan PSR (PSR-1, PSR-2, PSR-4, PSR-12). Ia menekankan peningkatan kebolehbacaan dan kebolehkerjaan kod melalui gaya yang konsisten, penamaan bermakna, dan EFF

Artikel ini meneroka mengoptimumkan deduplikasi array PHP untuk dataset yang besar. Ia mengkaji teknik-teknik seperti array_unique (), array_flip (), splobjectstorage, dan pra-sorting, membandingkan kecekapan mereka. Untuk dataset besar -besaran, ia mencadangkan pemotongan, pangkalan data

Butiran artikel ini memasang dan menyelesaikan masalah PHP, memberi tumpuan kepada PECL. Ia meliputi langkah pemasangan (mencari, memuat turun/menyusun, membolehkan, memulakan semula pelayan), teknik penyelesaian masalah (memeriksa log, mengesahkan pemasangan,

Artikel ini menerangkan API Refleksi PHP, membolehkan pemeriksaan runtime dan manipulasi kelas, kaedah, dan sifat. IT memperincikan kes penggunaan biasa (penjanaan dokumentasi, ORM, suntikan pergantungan) dan memberi amaran terhadap prestasi overhea
