檢索列名不明確的結果
從包含多個具有重疊列名的表的資料庫中擷取結果時,您可能會遇到歧義存取所需的值。在此範例中,我們遇到兩個表格:NEWS 和 USERS,它們都有一個「id」欄位。
問題陳述
要檢索新聞ID 和用戶ID,我們執行以下SQL 查詢:
SELECT * FROM news JOIN users ON news.user = user.id
但是,當使用關聯數組和PHP 存取結果時語法$row['column-name'],我們面臨著識別特定ID 欄位的挑戰。
解
為了解決這個歧義,我們可以將別名分配到選定的欄位。使用這些別名,我們可以明確地引用特定表中所需的列。
使用別名修改後的 SQL 查詢:
$query = 'SELECT news.id AS newsId, user.id AS userId, [OTHER FIELDS HERE] FROM news JOIN users ON news.user = user.id'
現在,在 PHP 中檢索結果時,我們可以使用用於存取列的別名,例如:
$newsId = $row['newsId']; $userId = $row['userId'];
以上是在 SQL 中檢索具有重疊列名的結果時如何避免歧義?的詳細內容。更多資訊請關注PHP中文網其他相關文章!