Nama Lajur Samar-samar dalam SQL JOINs: Dilema PHP
Apabila menyertai berbilang jadual dalam SQL, ia adalah perkara biasa untuk menemui nama lajur yang samar-samar, terutamanya apabila dua atau lebih jadual berkongsi lajur biasa. Ini boleh menyebabkan kesukaran untuk mendapatkan dan mengakses data yang dikehendaki apabila menggunakan PHP.
Masalahnya:
Pertimbangkan senario pangkalan data berikut:
Untuk mendapatkan ID berita dan ID pengguna, anda laksanakan SQL berikut:
SELECT * FROM news JOIN users ON news.user = user.id
Walau bagaimanapun, apabila anda mengambil keputusan dalam PHP dan cuba mengaksesnya menggunakan tatasusunan bersekutu, anda mungkin menghadapi kekaburan: nama lajur yang sama ("id") muncul dalam kedua-dua jadual NEWS dan USERS.
Penyelesaian: Column Aliasing
Untuk menyelesaikan kekaburan ini, anda boleh gunakan aliasing lajur dalam pertanyaan SQL anda. Aliasing membolehkan anda menetapkan alias unik pada lajur yang anda pilih, membolehkan anda membezakan antara lajur tersebut dalam kod PHP anda.
Untuk alias lajur dalam contoh anda:
$query = 'SELECT news.id AS newsId, user.id AS userId, [OTHER FIELDS HERE] FROM news JOIN users ON news.user = user.id'
Dengan menggunakan alias "newsId" dan "userId," kini anda boleh mengakses ID berita dan ID pengguna dalam PHP tanpa kesamaran:
$row['newsId']; // News ID $row['userId']; // User ID
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menyelesaikan Nama Lajur Samar-samar dalam SQL JOINs Apabila Menggunakan PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!