Pendapatan Hasil dengan Nama Lajur Kabur
Apabila mendapatkan semula hasil daripada pangkalan data yang mengandungi berbilang jadual dengan nama lajur yang bertindih, anda mungkin menghadapi kesamaran dalam mengakses nilai yang dikehendaki. Dalam contoh ini, kami menemui dua jadual: BERITA dan PENGGUNA, kedua-duanya mempunyai lajur 'id'.
Pernyataan Masalah
Untuk mendapatkan ID berita dan ID pengguna, kami melaksanakan pertanyaan SQL berikut:
SELECT * FROM news JOIN users ON news.user = user.id
Walau bagaimanapun, apabila mengakses keputusan dalam PHP menggunakan tatasusunan bersekutu dan sintaks $row['column-name'], kami menghadapi cabaran untuk mengenal pasti lajur ID tertentu.
Penyelesaian
Untuk menyelesaikan kekaburan ini, kami boleh menetapkan alias kepada lajur yang dipilih. Menggunakan alias ini, kami boleh merujuk secara eksplisit lajur yang dikehendaki daripada jadual tertentu.
Pertanyaan SQL yang diubah suai dengan alias:
$query = 'SELECT news.id AS newsId, user.id AS userId, [OTHER FIELDS HERE] FROM news JOIN users ON news.user = user.id'
Kini, apabila mendapatkan semula hasil dalam PHP, kita boleh menggunakan alias untuk mengakses lajur, contohnya:
$newsId = $row['newsId']; $userId = $row['userId'];
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengelakkan Kekaburan Apabila Mendapatkan Keputusan dengan Nama Lajur Bertindih dalam SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!