日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

MySQL 中行轉列的方法

瀏覽:262日期:2023-10-08 11:07:39

MySQL行轉列操作

所謂的行轉列操作,就是將一個表的行信息轉化為列信息,說著可能比較籠統,這里先舉個例子,如下:

+----+-----------+--------+-------+| ID | USER_NAME | COURSE | SCORE |+----+-----------+--------+-------+| | 張三 | 數學 | || | 張三 | 語文 | || | 張三 | 英語 | || | 李四 | 數學 | || | 李四 | 語文 | || | 李四 | 英語 | || | 王五 | 數學 | || | 王五 | 語文 | || | 王五 | 英語 | |+----+-----------+--------+-------+ rows in set (0.00 sec)+-----------+--------+--------+--------+| user_name | 數學 | 語文 | 英語 |+-----------+--------+--------+--------+| 張三 | | | || 李四 | | | || 王五 | | | |+-----------+--------+--------+--------+ rows in set (0.00 sec)

上面的例子中,表1給出了三個學生的三門成績,而表2是將表1的行記錄信息(學科、姓名)轉化為列信息,并根據不同的user_name進行分組顯示。

1 case when操作方法

要實現上面的功能,我們需要進行分析,首先,我們需要生成三個列,分別是數學,語文和英語,然后給每個列中的值填入對應的數據。這里需要用到mysql的case when then end操作,也就是條件操作,關于這個條件語句,首先我們給出解釋:

case colume when condition1 then result1 when condition2 then result2 when condition3 then result3else result4end

上面的語法,可以理解為當column的值符合condition1的時候,用result1去替換column的值,以此類推,當column值都不符合的時候,用result4去替換column的值。

現在開始試驗:

首先我們創建一張表,并插入如下數據:

mysql-yeyz ::>>select * from test_tbl;+----+-----------+--------+-------+| ID | USER_NAME | COURSE | SCORE |+----+-----------+--------+-------+| | 張三 | 數學 | || | 張三 | 語文 | || | 張三 | 英語 | || | 李四 | 數學 | || | 李四 | 語文 | || | 李四 | 英語 | || | 王五 | 數學 | || | 王五 | 語文 | || | 王五 | 英語 | |+----+-----------+--------+-------+ rows in set (0.00 sec)

根據上面case when語法,當碰到課程為’數學’的時候,我們定義一個列’數學’,并把它的score填入其中,如果碰到’語文’或者’英語’,那么把它替換為0,我們可以先籠統的寫出如下SQL:

mysql-yeyz ::>>SELECT user_name ,(CASE course WHEN ’數學’ THEN score ELSE END ) 數學 FROM test_tbl;+-----------+--------+| user_name | 數學 |+-----------+--------+| 張三 | || 張三 | || 張三 | || 李四 | || 李四 | || 李四 | || 王五 | || 王五 | || 王五 | |+-----------+--------+ rows in set (0.00 sec)

我們發現上面的表只有兩個列,根據SQL規則,我們可以把’語文’和’英語’的值也加入進去,一次性多寫幾個列,如下:

mysql-yeyz ::>>SELECT user_name , -> (CASE course WHEN ’數學’ THEN score ELSE END ) 數學, -> (CASE course WHEN ’語文’ THEN score ELSE END ) 語文, -> (CASE course WHEN ’英語’ THEN score ELSE END ) 英語 -> FROM test_tbl;+-----------+--------+--------+--------+| user_name | 數學 | 語文 | 英語 |+-----------+--------+--------+--------+| 張三 | | | || 張三 | | | || 張三 | | | || 李四 | | | || 李四 | | | || 李四 | | | || 王五 | | | || 王五 | | | || 王五 | | | |+-----------+--------+--------+--------+ rows in set (0.00 sec)

這下好了,我們有了所有的記錄了,已經快要達到我們的目的了,看看和最終結果的差距:

+-----------+--------+--------+--------+| user_name | 數學 | 語文 | 英語 |+-----------+--------+--------+--------+| 張三 | | | || 李四 | | | || 王五 | | | |+-----------+--------+--------+--------+

好像就剩把那些同名的學生信息都合并一下就好了,自然而然我們想到了group_by(user_name)的操作,而group_by操作需要和一些聚合函數(MAX,MIN,AVG,SUM,COUNT等)進行搭配。由于每條記錄中只包含當前學科的成績,其他學科的成績為0,所以我們使用MAX函數和SUM函數的結果是相同的,但是不能使用AVG函數和MIN函數,這應該很好理解吧。

下面我們給出最終結果:

mysql-yeyz 13:55:52>>SELECT user_name , -> MAX(CASE course WHEN ’數學’ THEN score ELSE END ) 數學, -> MAX(CASE course WHEN ’語文’ THEN score ELSE END ) 語文, -> MAX(CASE course WHEN ’英語’ THEN score ELSE END ) 英語 -> FROM test_tbl -> GROUP BY USER_NAME;+-----------+--------+--------+--------+| user_name | 數學 | 語文 | 英語 |+-----------+--------+--------+--------+| 張三 | 34 | 58 | 58 || 李四 | 45 | 87 | 45 || 王五 | 76 | 34 | 89 |+-----------+--------+--------+--------+3 rows in set (0.00 sec)mysql-yeyz ::>>SELECT user_name , -> sum(CASE course WHEN ’數學’ THEN score ELSE END ) 數學, -> sum(CASE course WHEN ’語文’ THEN score ELSE END ) 語文, -> sum(CASE course WHEN ’英語’ THEN score ELSE END ) 英語 -> FROM test_tbl -> GROUP BY USER_NAME;+-----------+--------+--------+--------+| user_name | 數學 | 語文 | 英語 |+-----------+--------+--------+--------+| 張三 | 34 | 58 | 58 || 李四 | 45 | 87 | 45 || 王五 | 76 | 34 | 89 |+-----------+--------+--------+--------+3 rows in set (0.00 sec)mysql-yeyz ::>>SELECT user_name , -> MIN(CASE course WHEN ’數學’ THEN score ELSE END ) 數學, -> MIN(CASE course WHEN ’語文’ THEN score ELSE END ) 語文, -> MIN(CASE course WHEN ’英語’ THEN score ELSE END ) 英語 -> FROM test_tbl -> GROUP BY USER_NAME;+-----------+--------+--------+--------+| user_name | 數學 | 語文 | 英語 |+-----------+--------+--------+--------+| 張三 | 0 | 0 | 0 || 李四 | 0 | 0 | 0 || 王五 | 0 | 0 | 0 |+-----------+--------+--------+--------+3 rows in set (0.00 sec)

可以看出來,使用MAX和使用SUM的結果是一樣的,但是使用MIN作為聚合函數,會導致最終輸出的結果都是0,因為每次都選的是該user_name指定學科的最小的值,也就是0。這樣的結果就很好理解了。

2 if操作方法

上面的case when操作方法理解了,那么if的操作方法也很好理解,原理是一樣的,只不過是把case when的語法轉換為if方式,如下

mysql-yeyz 14:12:42>>SELECT user_name , -> MAX(if (course= ’數學’,score,) ) 數學, -> MAX(if (course= ’語文’,score,) ) 語文, -> MAX(if (course= ’英語’,score,) ) 英語 -> FROM test_tbl -> GROUP BY USER_NAME;+-----------+--------+--------+--------+| user_name | 數學 | 語文 | 英語 |+-----------+--------+--------+--------+| 張三 | 34 | 58 | 58 || 李四 | 45 | 87 | 45 || 王五 | 76 | 34 | 89 |+-----------+--------+--------+--------+3 rows in set (0.00 sec)

3 添加total列

當我們把基本的行轉列實現之后,我們現在需要在轉換之后的表上面添加一個total字段,這個字段的添加我們可以通過下面的方法,即在最開始統計的時候,就把score值也統計進去,如下:

mysql-yeyz 14:18:06>>SELECT user_name , -> (CASE course WHEN ’數學’ THEN score ELSE END ) 數學, -> (CASE course WHEN ’語文’ THEN score ELSE END ) 語文, -> (CASE course WHEN ’英語’ THEN score ELSE END ) 英語, -> (score) total -> FROM test_tbl;+-----------+--------+--------+--------+-------+| user_name | 數學 | 語文 | 英語 | total |+-----------+--------+--------+--------+-------+| 張三 | 34 | 0 | 0 | 34 || 張三 | 0 | 58 | 0 | 58 || 張三 | 0 | 0 | 58 | 58 || 李四 | 45 | 0 | 0 | 45 || 李四 | 0 | 87 | 0 | 87 || 李四 | 0 | 0 | 45 | 45 || 王五 | 76 | 0 | 0 | 76 || 王五 | 0 | 34 | 0 | 34 || 王五 | 0 | 0 | 89 | 89 |+-----------+--------+--------+--------+-------+9 rows in set (0.00 sec)

上面的結果是沒有聚合后的結果,這里需要注意的是,如果我們要聚合,前三個列可以使用sum或者max的方法,最后一個列一定要使用sum的方法,因為我們要求的是總成績,使用max的方法會導致取值變為分數最高的那個值。最后的sql如下:

mysql-yeyz 14:18:29>>SELECT user_name , -> sum(CASE course WHEN ’數學’ THEN score ELSE END ) 數學, -> sum(CASE course WHEN ’語文’ THEN score ELSE END ) 語文, -> sum(CASE course WHEN ’英語’ THEN score ELSE END ) 英語, -> sum(score) total -> FROM test_tbl -> GROUP BY USER_NAME;+-----------+--------+--------+--------+-------+| user_name | 數學 | 語文 | 英語 | total |+-----------+--------+--------+--------+-------+| 張三 | 34 | 58 | 58 | 150 || 李四 | 45 | 87 | 45 | 177 || 王五 | 76 | 34 | 89 | 199 |+-----------+--------+--------+--------+-------+3 rows in set (0.00 sec)

4 簡單方法 group_concat

如果我們對于結果的顯示格式要求不是那么細致的話,也可以用一種粗獷的方法,就是group_concat函數,將所有的列都寫在一起,用一個字段表示,效果如下:

mysql-yeyz 14:19:13>>SELECT user_name,GROUP_CONCAT(`course`,':',score)AS 成績 FROM test_tbl GROUP BY user_name;+-----------+-------------------------------+| user_name | 成績 |+-----------+-------------------------------+| 張三 | 數學:34,語文:58,英語:58 || 李四 | 數學:45,語文:87,英語:45 || 王五 | 數學:76,語文:34,英語:89 |+-----------+-------------------------------+3 rows in set (0.00 sec)

這種方法相當于直接針對原始表做了一個分組,也能夠應付一定的應用場景。

以上就是MySQL 中行轉列的方法的詳細內容,更多關于MySQL 行轉列的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产日韩欧美在线播放不卡| 国产日本久久| 三级欧美在线一区| 欧美理论视频| 国产精品免费看| 国产精品免费看| 热久久国产精品| 日韩精品导航| 国产精品多人| 精品国产日韩欧美精品国产欧美日韩一区二区三区 | 中文字幕人成乱码在线观看 | 国产精品巨作av| 高清久久精品| 91精品国产成人观看| 国产精品婷婷| 亚洲精品自拍| 国产精品一国产精品k频道56| 久久不卡国产精品一区二区| 国产高清日韩| 日本欧美不卡| 亚洲尤物av| 国产精品永久| 久久狠狠婷婷| 久久国产99| 日韩精品久久理论片| 国产精品久久久久久模特| 电影91久久久| 欧美日韩国产探花| 久久国产精品美女| 成人精品天堂一区二区三区| 欧美精品导航| 91欧美日韩| 爽好多水快深点欧美视频| 国产精品久久久久久模特 | 夜久久久久久| 亚洲成人国产| 日韩三级精品| 麻豆精品av| 欧美xxxx性| 亚洲播播91| 亚洲一区国产| 国产精品入口久久| 91精品久久久久久久久久不卡| 美女久久一区| 国产精品极品| 国产一区二区精品| 另类欧美日韩国产在线| 久久精品播放| 国产欧美午夜| 欧美日韩在线观看视频小说| 日韩在线观看中文字幕| 91亚洲国产成人久久精品| 日韩一级欧洲| 国产精品777777在线播放 | 亚洲一区黄色| 丰满少妇一区| 亚洲一区二区三区四区电影| 国产精品.xx视频.xxtv| 9国产精品视频| 粉嫩av一区二区三区四区五区| 一本色道精品久久一区二区三区| 国产日产精品一区二区三区四区的观看方式 | 日本少妇一区| 久久国产三级| 国内精品福利| 国产欧美69| 伊人久久视频| 亚洲福利精品| 成人av二区| 久久久9色精品国产一区二区三区| 日本不卡在线视频| 日本在线不卡视频| 欧美激情精品| 亚洲黄色免费看| 久久99久久久精品欧美| 在线综合亚洲| 中文字幕在线看片| 蜜桃久久久久久| 亚洲一区资源| 欧美日韩伊人| 三级亚洲高清视频| 999国产精品| 麻豆成人av在线| 日韩国产精品久久久| 婷婷久久一区| 在线中文字幕播放| 97久久精品| 喷白浆一区二区| 性欧美xxxx免费岛国不卡电影| 久久不卡日韩美女| 日韩午夜视频在线| 国产精品色网| 久久久一二三| 超级白嫩亚洲国产第一| 国产精品天天看天天狠| 亚洲香蕉视频| 国产一级一区二区| 欧美 日韩 国产一区二区在线视频| 久久久久久色| 蜜臀久久久99精品久久久久久| 日韩中文欧美| 精品三级av在线导航| 日本91福利区| 天使萌一区二区三区免费观看| 久久国产中文字幕| 色偷偷色偷偷色偷偷在线视频| 久久精品国产久精国产| 日av在线不卡| 香蕉成人久久| 午夜亚洲精品| 亚洲欧美久久| 国产欧美日韩精品一区二区免费| 日韩专区在线视频| 麻豆精品新av中文字幕| 首页欧美精品中文字幕| 美女尤物久久精品| 欧美日韩国产亚洲一区| 在线精品小视频| 婷婷成人基地| 丝袜美腿一区二区三区| 亚洲最新无码中文字幕久久| 日韩精品欧美成人高清一区二区| 亚洲www啪成人一区二区| 精品久久在线| 色偷偷色偷偷色偷偷在线视频| 日韩一区三区| 三级小说欧洲区亚洲区| 999精品色在线播放| 久久三级视频| 在线精品小视频| 久久午夜视频| 亚洲精品黄色| 国产乱人伦丫前精品视频| 国产欧美欧美| 国内不卡的一区二区三区中文字幕| 岛国精品一区| 久久精品亚洲人成影院| 免费观看久久av| 欧美特黄一区| 亚洲久久一区| 国产日产一区| 91视频一区| 亚洲精品2区| 四虎精品一区二区免费| 国产日韩亚洲欧美精品| 久久精品国产精品亚洲毛片| 日韩电影二区| 欧美.日韩.国产.一区.二区| 国产精品色网| 91成人在线精品视频| 麻豆国产一区| 精精国产xxxx视频在线播放| 悠悠资源网久久精品| 一区二区三区四区在线观看国产日韩| 蜜桃久久av一区| 国产精品17p| 久久婷婷激情| 亚洲tv在线| 国产在线日韩精品| 欧美手机在线| 女人天堂亚洲aⅴ在线观看| 日本午夜精品久久久久| 最新日韩av| 亚洲久草在线| 欧美日韩在线观看视频小说| 国产欧美日韩精品一区二区免费 | 成人午夜在线| 欧美在线综合| 精品国产亚洲日本| 人人精品久久| 精品亚洲自拍| 99香蕉国产精品偷在线观看 | 精品资源在线| 亚洲特色特黄| 欧美久久一区二区三区| 欧美黄页在线免费观看| 亚洲福利国产| 久久国产乱子精品免费女| 日本不卡免费高清视频在线| 六月天综合网| 日本久久黄色| 亚洲乱码视频| 日韩精品不卡一区二区| 中文字幕视频精品一区二区三区| 久久精品国产999大香线蕉| 好看不卡的中文字幕| 国产精品一区二区三区www| 日韩精品一卡| 欧美一级二区| 激情五月综合网| 久久精品超碰| 欧美aa国产视频| 国产极品一区| 亚洲欧美日韩国产一区二区| 久久精品国产99国产| 蜜臀久久久99精品久久久久久| а√天堂8资源中文在线| 日韩精品欧美精品| 亚洲国产不卡| 国产成人精品一区二区三区视频|