簡(jiǎn)單談?wù)凪ySQL數(shù)據(jù)透視表
我有一張這樣的產(chǎn)品零件表:
部分
part_id part_type product_id -------------------------------------- 1 A 1 2 B 1 3 A 2 4 B 2 5 A 3 6 B 3
我想要一個(gè)返回如下表格的查詢:
product_id part_A_id part_B_id ---------------------------------------- 1 1 2 2 3 4 3 5 6
在實(shí)際實(shí)施中,將有數(shù)百萬個(gè)產(chǎn)品部件
最佳答案
不幸的是,MySQL沒有PIVOT功能,但您可以使用聚合函數(shù)和CASE語句對(duì)其進(jìn)行建模.對(duì)于動(dòng)態(tài)版本,您需要使用預(yù)準(zhǔn)備語句:
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;
如果您只有幾列,那么您可以使用靜態(tài)版本:
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
總結(jié)
以上是腳本之家為你收集整理的MySQL動(dòng)態(tài)透視全部?jī)?nèi)容,希望文章能夠幫你解決MySQL動(dòng)態(tài)透視所遇到的程序開發(fā)問題。
相關(guān)文章
使用Memcache緩存mysql數(shù)據(jù)庫(kù)操作的原理和緩存過程淺析
這篇文章主要介紹了使用Memcache緩存mysql數(shù)據(jù)庫(kù)操作的原理和緩存過程淺析,本文著重點(diǎn)在Memcache和MySQL數(shù)據(jù)庫(kù)的交互過程及流程分解,需要的朋友可以參考下2014-07-07
MySQL同步數(shù)據(jù)Replication的實(shí)現(xiàn)步驟
本文主要介紹了MySQL同步數(shù)據(jù)Replication的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03
MySQL MHA 運(yùn)行狀態(tài)監(jiān)控介紹
這篇文章主要介紹MySQL MHA 運(yùn)行狀態(tài)監(jiān)控,MHA(Master HA)是一款開源的 MySQL 的高可用程序,它為 MySQL 主從復(fù)制架構(gòu)提供了 automating master failover 功能,想具體了解的小伙伴可以和小編一起學(xué)習(xí)下面文章內(nèi)容2021-10-10
MySQL?bit類型增加索引后查詢結(jié)果不正確案例解析
這篇文章主要介紹了MySQL?bit類型增加索引后查詢結(jié)果不正確案例淺析,我們先創(chuàng)建表student_attend,初始化一些數(shù)據(jù),這篇文章的測(cè)試環(huán)境為MySQL 8.0.35社區(qū)版,具體內(nèi)容介紹跟隨小編一起學(xué)習(xí)吧2024-06-06
mysql存儲(chǔ)過程如何利用臨時(shí)表返回結(jié)果集
這篇文章主要介紹了mysql存儲(chǔ)過程如何利用臨時(shí)表返回結(jié)果集,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09

