Soalan:
Dalam pangkalan data dengan berbilang lajur (cth., "nama," "umur," "jantina," dan "kedudukan"), bagaimana kita boleh mendapatkan tatasusunan bersekutu dalam format tertentu menggunakan kaedah fetchAll PDO, di mana setiap kunci tatasusunan ialah medan daripada lajur yang ditentukan (cth., "nama" ) dan nilainya ialah baris yang sepadan untuk kunci itu?
Jawapan:
Menggunakan kaedah fetchAll PDO, kami boleh menentukan bendera berikut untuk mencapai hasil yang diingini:
<code class="php">->fetchAll(\PDO::FETCH_GROUP|\PDO::FETCH_UNIQUE);</code>
Dengan menggabungkan FETCH_GROUP dan FETCH_UNIQUE, PDO akan mengumpulkan hasil secara automatik mengikut lajur yang ditentukan dan menetapkan lajur pertama sebagai kunci untuk setiap kumpulan, sementara tidak termasuk rekod pendua. Ini menghapuskan tahap sarang tambahan atau keperluan untuk operasi pasca pemprosesan seperti semasa.
Contoh:
Pertimbangkan set data sampel berikut:
name | age | sex | position |
---|---|---|---|
Antony | 34 | M | programmer |
Sally | 30 | F | manager |
Matthew | 28 | M | designer |
Menggunakan kaedah pengambilan yang disyorkan, kami boleh mendapatkan semula tatasusunan hasil yang diingini:
<code class="php">$result = $pdo->query('SELECT * FROM employee')->fetchAll(\PDO::FETCH_GROUP|\PDO::FETCH_UNIQUE); print_r($result);</code>
Ini akan mengeluarkan tatasusunan bersekutu berikut:
Array ( [Antony] => Array ( [age] => 34 [sex] => M [position] => programmer ) [Sally] => Array ( [age] => 30 [sex] => F [position] => manager ) [Matthew] => Array ( [age] => 28 [sex] => M [position] => designer ) )
Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Susunan Bersekutu Dikumpulkan Mengikut Lajur Khusus dengan PDO?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!