久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

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

SQL如何實現(xiàn)橫表與縱表相互轉(zhuǎn)換

瀏覽:236日期:2023-05-02 10:03:21
目錄
  • 一、橫表簡單概述
  • 二、縱表簡單概述
  • 三、縱表轉(zhuǎn)橫表代碼如下以及視圖展示
  • 四、橫表轉(zhuǎn)縱表代碼如下以及視圖展示
  • 五、橫表、縱表優(yōu)點與缺點
  • 六、總結(jié)

一、橫表簡單概述

橫表是普通的建表方式。例如:表結(jié)構為主鍵、字段1、字段2、字段3…。

二、縱表簡單概述

縱表的表結(jié)構為主鍵、字段代碼、字段值,字段代碼則為字段1、字段2、字段3…。

三、縱表轉(zhuǎn)橫表代碼如下以及視圖展示

1.縱表視圖如下:

2.縱表轉(zhuǎn)換成橫表視圖如下:

3.sql語句如下所示:

select student_name,	sum(case ts.subject when "C語言" then ts.score else "" end) as C語言,	sum(case ts.subject when "數(shù)據(jù)結(jié)構" then ts.score else "" end) as 數(shù)據(jù)結(jié)構,	sum(case ts.subject when "操作系統(tǒng)" then ts.score else "" end) as 操作系統(tǒng)from t_student tsgroup by ts.student_name;

四、橫表轉(zhuǎn)縱表代碼如下以及視圖展示

1.橫表視圖如下:

2.橫表轉(zhuǎn)換成縱表視圖如下:

3.sql語句如下所示:

select ts.studnet_name,"C語言" as 科目,ts.`C語言` as 成績from t_student1 tsunion allselect ts.studnet_name,"數(shù)據(jù)結(jié)構" as 科目,ts.`數(shù)據(jù)結(jié)構` as 成績from t_student1 tsunion allselect ts.studnet_name,"操作系統(tǒng)" as 科目,ts.`操作系統(tǒng)` as 成績from t_student1 tsorder by studnet_name,科目

五、橫表、縱表優(yōu)點與缺點

1.橫表
優(yōu)點:一行表示了一個實體記錄,清晰可見。
缺點:如果現(xiàn)在要給這個表加一個字段,那么就必須重建表結(jié)構。

2.縱表
優(yōu)點:如果現(xiàn)在要給這個表加一個字段,只需要添加一些記錄。
缺點:數(shù)據(jù)描述不是很清晰,而且會造成數(shù)據(jù)庫數(shù)據(jù)很多。另如果需要分組統(tǒng)計,要先group by,較繁瑣

六、總結(jié)

應該把不容易改動表結(jié)構的設計成橫表,把容易經(jīng)常改動不確定的表結(jié)構設計成縱表。

到此這篇關于SQL如何實現(xiàn)橫表與縱表相互轉(zhuǎn)換的文章就介紹到這了,更多相關SQL 橫表與縱表轉(zhuǎn)換內(nèi)容請搜索以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持!

標簽: MsSQL
主站蜘蛛池模板: 青川县| 成武县| 石棉县| 曲阳县| 辽源市| 固镇县| 博白县| 齐河县| 余庆县| 彩票| 中卫市| 枣阳市| 达拉特旗| 龙江县| 鲜城| 石门县| 宁河县| 明光市| 东乡族自治县| 瑞丽市| 金华市| 文昌市| 娱乐| 河曲县| 柘荣县| 东山县| 师宗县| 佛坪县| 寻乌县| 乌拉特中旗| 宁阳县| 新巴尔虎左旗| 阜新市| 佛坪县| 株洲县| 乌拉特前旗| 阳城县| 法库县| 闻喜县| 光泽县| 西充县|