您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“MySQL數據透視表的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“MySQL數據透視表的示例分析”這篇文章吧。
我有一張這樣的產品零件表:
部分
part_id part_type product_id -------------------------------------- 1 A 1 2 B 1 3 A 2 4 B 2 5 A 3 6 B 3
我想要一個返回如下表格的查詢:
product_id part_A_id part_B_id ---------------------------------------- 1 1 2 2 3 4 3 5 6
在實際實施中,將有數百萬個產品部件
最佳答案
不幸的是,MySQL沒有PIVOT功能,但您可以使用聚合函數和CASE語句對其進行建模.對于動態版本,您需要使用預準備語句:
SET @sql = NULL; SELECT GROUP_CONCAT(DISTINCT CONCAT( 'max(case when part_type = ''',part_type,''' then part_id end) AS part_','_id' ) ) INTO @sql FROM parts; SET @sql = CONCAT('SELECT product_id,',@sql,' FROM parts GROUP BY product_id'); PREPARE stmt FROM @sql; EXECUTE stmt; DEALLOCATE PREPARE stmt;
如果您只有幾列,那么您可以使用靜態版本:
select product_id,max(case when part_type ='A' then part_id end) as Part_A_Id,max(case when part_type ='B' then part_id end) as Part_B_Id from parts group by product_id
以上是“MySQL數據透視表的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。