Menggunakan PDO untuk Mendapatkan Susunan Bersekutu Dikumpulkan Mengikut Nilai Lajur
Dalam operasi pangkalan data, selalunya diperlukan untuk mendapatkan semula data yang disusun dalam format tertentu . Satu format sedemikian ialah tatasusunan bersekutu yang dikumpulkan mengikut nilai lajur tertentu. Ini membolehkan akses mudah kepada data berdasarkan lajur yang ditentukan. Berikut ialah perbincangan tentang cara untuk mencapai ini menggunakan PDO.
Masalah: Diberi jadual dengan data berikut:
name | age | sex | position |
---|---|---|---|
Antony | 34 | M | programmer |
Sally | 30 | F | manager |
Matthew | 28 | M | designer |
Matlamat: Ambil data dalam format 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 ) )
Penyelesaian: Untuk mencapai ini, anda boleh menggunakan kaedah fetchAll PDO dengan mod berikut:
$pdo->query('SELECT * FROM employee')->fetchAll(PDO::FETCH_GROUP|PDO::FETCH_UNIQUE);
The Mod FETCH_GROUP mengumpulkan hasil mengikut nilai lajur pertama. Mod FETCH_UNIQUE mengehadkan hasil kepada satu baris untuk setiap nilai unik dalam lajur pengumpulan. Akibatnya, anda mendapat tatasusunan bersekutu dengan nilai lajur berfungsi sebagai kunci dan lajur selebihnya sebagai nilai.
Contoh Output:
Array ( [Antony] => Array ( [0] => (age: 34, sex: M, position: programmer) ) [Sally] => Array ( [0] => (age: 30, sex: F, position: manager) ) [Matthew] => Array ( [0] => (age: 28, sex: M, position: designer) ) )
Perhatikan bahawa output mengandungi tatasusunan dengan satu baris untuk setiap kumpulan. Ini kerana mod FETCH_UNIQUE memastikan bahawa hanya baris pertama untuk setiap kumpulan diambil.
Atas ialah kandungan terperinci Bagaimana Menggunakan PDO untuk Mendapatkan Susunan Bersekutu Dikumpulkan Mengikut Nilai Lajur?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!