MySQL:從多個結構相同但資料不同的表中選擇資料
在管理大型資料集時,經常需要將資料儲存在多個表中用於本地化或分區目的的具有相同架構的表。然而,從多個表中提取資料同時保持特定的排序順序可能會帶來挑戰。
問題:WHERE 子句中出現不明確的列錯誤
考慮以下MySQL 語句:
SELECT * from us_music, de_music where `genre` = 'punk'
此查詢嘗試連接來自兩句:
#1052 - Column 'genre' in where clause is ambiguous
此查詢嘗試連接來自兩句:
此查詢嘗試連接來自兩句:(SELECT * from us_music where `genre` = 'punk') UNION (SELECT * from de_music where `genre` = 'punk')
解決方案:使用 UNION 子句
要解決歧義,可以使用 UNION 子句。 UNION 子句將多個 SELECT 語句的結果組合成一個結果集。以下是在這種情況下如何使用它:
(SELECT * from us_music where `genre` = 'punk') UNION (SELECT * from de_music where `genre` = 'punk') ORDER BY `band_name`
此查詢首先從 us_music 中選擇流派等於“punk”的數據,然後對 de_music 執行相同的操作。然後,兩個 SELECT 語句的結果將會組合成一個結果集。
將組合結果排序組合資料後,您可以指定排序順序在UNION 語句後面加上ORDER BY 子句:此查詢將合併兩個表中的資料並對結果進行排序基於band_name 欄位。以上是如何有效率地從多個相同結構的MySQL表中選取資料?的詳細內容。更多資訊請關注PHP中文網其他相關文章!