欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql實現(xiàn)列轉(zhuǎn)行和行轉(zhuǎn)列方式

 更新時間:2025年08月05日 10:03:52   作者:北風toto  
這篇文章主要介紹了mysql實現(xiàn)列轉(zhuǎn)行和行轉(zhuǎn)列方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

1、行轉(zhuǎn)列(將多行數(shù)據(jù)轉(zhuǎn)為單行多列)

1.1、使用 CASE WHEN + 聚合函數(shù)

SELECT 
    id,
    MAX(CASE WHEN subject = '數(shù)學' THEN score ELSE NULL END) AS '數(shù)學',
    MAX(CASE WHEN subject = '語文' THEN score ELSE NULL END) AS '語文',
    MAX(CASE WHEN subject = '英語' THEN score ELSE NULL END) AS '英語'
FROM student_scores
GROUP BY id;

1.2、使用 IF + 聚合函數(shù)

SELECT 
    id,
    MAX(IF(subject = '數(shù)學', score, NULL)) AS '數(shù)學',
    MAX(IF(subject = '語文', score, NULL)) AS '語文',
    MAX(IF(subject = '英語', score, NULL)) AS '英語'
FROM student_scores
GROUP BY id;

1.3、使用 PIVOT (MySQL 8.0+)

SELECT 
    id,
    JSON_UNQUOTE(JSON_EXTRACT(pivot_data, '$.數(shù)學')) AS '數(shù)學',
    JSON_UNQUOTE(JSON_EXTRACT(pivot_data, '$.語文')) AS '語文',
    JSON_UNQUOTE(JSON_EXTRACT(pivot_data, '$.英語')) AS '英語'
FROM (
    SELECT 
        id,
        JSON_OBJECTAGG(subject, score) AS pivot_data
    FROM student_scores
    GROUP BY id
) AS t;

1.4、dataworks使用wm_concat函數(shù)和keyvalue

  • 缺點:當字符串存在英文冒號時會導致獲取的值為空;中文冒號不受影響
  • 如果存在重復的數(shù)據(jù),將導致取數(shù)時隨機取其中一個;核心原因為wm_concat函數(shù)在拼接時順序不固定,哪怕是增加了order by也沒有用
  • keyvalue從字符串中取值時,如果有重復key,從左到右取第一個key的值
select  id
        ,keyvalue(column_value,'name') as name
        ,keyvalue(column_value,'age') as age
from    (
            select  id
                    ,wm_concat(';',concat(obj_name,':',obj_value)) as column_value
            from    school
            group by id
        ) 
;
-- 如果值存在英文冒號,導致取值為空的原因,看下面兩個sql例子即可理解
-- 返回null
select keyvalue('name:小紅:3737;age:13','name');
-- 返回3737
select keyvalue('name:小紅:3737;age:13','name:小紅');

2、列轉(zhuǎn)行(將多列數(shù)據(jù)轉(zhuǎn)為多行)

2.1、使用 UNION ALL

SELECT id, '數(shù)學' AS subject, 數(shù)學 AS score FROM student_scores_pivot
UNION ALL
SELECT id, '語文' AS subject, 語文 AS score FROM student_scores_pivot
UNION ALL
SELECT id, '英語' AS subject, 英語 AS score FROM student_scores_pivot
ORDER BY id, subject;

2.2、使用 CROSS JOIN + 條件篩選

  • 優(yōu)點是不用頻繁讀取磁盤
SELECT 
    s.id,
    c.subject,
    CASE c.subject
        WHEN '數(shù)學' THEN s.數(shù)學
        WHEN '語文' THEN s.語文
        WHEN '英語' THEN s.英語
    END AS score
FROM student_scores_pivot s
CROSS JOIN (
    SELECT '數(shù)學' AS subject UNION ALL
    SELECT '語文' UNION ALL
    SELECT '英語'
) c;
  • 同樣的語句,使用values和row
SELECT 
    s.id,
    c.subject,
    CASE c.subject
        WHEN '數(shù)學' THEN s.數(shù)學
        WHEN '語文' THEN s.語文
        WHEN '英語' THEN s.英語
    END AS score
FROM student_scores_pivot s
CROSS JOIN (
	values
    row('數(shù)學') 
    ,row('語文')
    ,row('英語')
) c(subject);

2.3、使用 JSON 函數(shù) (MySQL 8.0+)

SELECT 
    id,
    jt.subject,
    jt.score
FROM student_scores_pivot,
JSON_TABLE(
    JSON_OBJECT(
        '數(shù)學', 數(shù)學,
        '語文', 語文,
        '英語', 英語
    ),
    '$.*' COLUMNS(
        subject VARCHAR(10) PATH '$.key',
        score INT PATH '$.value'
    )
) AS jt;

3、動態(tài)行轉(zhuǎn)列

  • 對于不確定列名的情況,可以使用存儲過程動態(tài)生成SQL:
DELIMITER //
CREATE PROCEDURE dynamic_pivot(IN table_name VARCHAR(100), IN row_id VARCHAR(100), IN pivot_col VARCHAR(100), IN value_col VARCHAR(100))
BEGIN
    DECLARE done INT DEFAULT FALSE;
    DECLARE col_name VARCHAR(100);
    DECLARE col_list TEXT DEFAULT '';
    DECLARE cur CURSOR FOR 
        SELECT DISTINCT pivot_col FROM table_name;
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
    
    OPEN cur;
    read_loop: LOOP
        FETCH cur INTO col_name;
        IF done THEN
            LEAVE read_loop;
        END IF;
        SET col_list = CONCAT(col_list, 
            IF(col_list = '', '', ', '), 
            'MAX(CASE WHEN ', pivot_col, ' = ''', col_name, ''' THEN ', value_col, ' ELSE NULL END) AS `', col_name, '`');
    END LOOP;
    CLOSE cur;
    
    SET @sql = CONCAT('SELECT ', row_id, ', ', col_list, ' FROM ', table_name, ' GROUP BY ', row_id, ';');
    PREPARE stmt FROM @sql;
    EXECUTE stmt;
    DEALLOCATE PREPARE stmt;
END //
DELIMITER ;

-- 調(diào)用存儲過程
CALL dynamic_pivot('student_scores', 'id', 'subject', 'score');

4、詳細測試demo

4.1、dataworks使用wm_concat函數(shù)和keyvalue實現(xiàn)行轉(zhuǎn)列

-- 創(chuàng)建表
create table if not exists school (
`id` string,
`obj_name` string,
`obj_value` string
);

-- 插入測試數(shù)據(jù)
insert into school
values 
('1','name','小明'),
('1','age','12'),
('2','name','小紅'),
('2','age','13')
;


-- 列轉(zhuǎn)行
select  id
        ,keyvalue(column_value,'name') as name
        ,keyvalue(column_value,'age') as age
from    (
            select  id
                    ,wm_concat(';',concat(obj_name,':',obj_value)) as column_value
            from    school
            group by id
        ) 
;

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Navicat for Mysql 字段注釋中文亂碼問題及解決

    Navicat for Mysql 字段注釋中文亂碼問題及解決

    這篇文章主要介紹了Navicat for Mysql 字段注釋中文亂碼問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • MySQL學習必備條件查詢數(shù)據(jù)

    MySQL學習必備條件查詢數(shù)據(jù)

    這篇文章主要介紹了MySQL學習必備條件查詢數(shù)據(jù),首先通過利用where語句可以對數(shù)據(jù)進行篩選展開主題相關(guān)內(nèi)容,具有一定的參考價值,需要的小伙伴可以參考一下,希望對你有所幫助
    2022-03-03
  • 將數(shù)據(jù)插入到MySQL表中的詳細教程

    將數(shù)據(jù)插入到MySQL表中的詳細教程

    這篇文章主要介紹了將數(shù)據(jù)插入到MySQL表中的詳細教程,文中給出了在PHP腳本中操作的示例,是MySQL入門學習中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-05-05
  • Mac上安裝MySQL過程分享

    Mac上安裝MySQL過程分享

    這篇文章主要介紹了Mac上安裝MySQL過程分享,本文共分4步完成,簡單易懂,需要的朋友可以參考下
    2014-11-11
  • MySQL如何保證備份數(shù)據(jù)的一致性詳解

    MySQL如何保證備份數(shù)據(jù)的一致性詳解

    在高并發(fā)的場景下,大量的請求直接訪問Mysql很容易造成性能問題,下面這篇文章主要給大家介紹了關(guān)于MySQL如何保證備份數(shù)據(jù)一致性的相關(guān)資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2022-05-05
  • Mysql5.7.14 linux版密碼忘記完美解決辦法

    Mysql5.7.14 linux版密碼忘記完美解決辦法

    這篇文章主要介紹了Mysql5.7.14 linux版密碼忘記完美解決辦法,需要的朋友可以參考下
    2017-08-08
  • MySQL中DROP、DELETE與TRUNCATE的對比分析

    MySQL中DROP、DELETE與TRUNCATE的對比分析

    在MySQL數(shù)據(jù)庫操作中,DROP、DELETE和TRUNCATE是三個常用的數(shù)據(jù)操作命令,本文將從多個維度對這三個命令進行詳細對比和解析,幫助讀者更好地掌握它們的應用,感興趣的朋友一起看看吧
    2025-07-07
  • Linux系統(tǒng)利用crontab定時備份Mysql數(shù)據(jù)庫方法

    Linux系統(tǒng)利用crontab定時備份Mysql數(shù)據(jù)庫方法

    本文教你如果快速利用系統(tǒng)crontab來定時執(zhí)行備份文件,按日期對備份結(jié)果進行保存
    2021-09-09
  • Windows?11?和?Rocky?9?Linux?平臺?MySQL?8.0.33?簡易安裝詳細教程

    Windows?11?和?Rocky?9?Linux?平臺?MySQL?8.0.33?簡易安裝詳細教程

    這篇文章主要介紹了Windows?11和Rocky9?Linux平臺MySQL8.0.33簡易安裝教程,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-05-05
  • MySQL如何查看正在運行的SQL詳解

    MySQL如何查看正在運行的SQL詳解

    在項目開發(fā)里面總是要查看后臺執(zhí)行的sql語句,mysql數(shù)據(jù)庫也不例外,下面這篇文章主要給大家介紹了關(guān)于MySQL如何查看正在運行的SQL的相關(guān)資料,文中介紹的非常詳細,需要的朋友可以參考下
    2023-01-01

最新評論