Rumah >pembangunan bahagian belakang >tutorial php >Bagaimanakah Saya Boleh Mengelakkan Kekaburan Apabila Mendapatkan Keputusan dengan Nama Lajur Bertindih dalam SQL?

Bagaimanakah Saya Boleh Mengelakkan Kekaburan Apabila Mendapatkan Keputusan dengan Nama Lajur Bertindih dalam SQL?

Susan Sarandon
Susan Sarandonasal
2024-12-06 10:16:12948semak imbas

How Can I Avoid Ambiguity When Retrieving Results with Overlapping Column Names in SQL?

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!

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