Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk Mendapatkan Susunan Bersekutu Dikumpulkan Mengikut Lajur Khusus dengan PDO?

Bagaimana untuk Mendapatkan Susunan Bersekutu Dikumpulkan Mengikut Lajur Khusus dengan PDO?

Linda Hamilton
Linda Hamiltonasal
2024-10-22 07:40:02969semak imbas

How to Retrieve Associative Arrays Grouped by Specific Column with PDO?

Mengambil Tatasusunan Bersekutu Dihimpunkan mengikut Nilai Lajur dengan PDO

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!

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