久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

使用 UNPIVOT 將列轉換為行

Transposing columns to rows using UNPIVOT(使用 UNPIVOT 將列轉換為行)
本文介紹了使用 UNPIVOT 將列轉換為行的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我有一個表格,由于某種原因,它有這樣的硬編碼值:

I have a table that for some reason has hardcoded values like so:

Row ID    QtyC1   QtyC2  QtyC3   QtyC4  QtyN1   QtyN2  QtyN3   QtyN4  
100       10      5      8       9      11      12     5       6
101       9       11     12      5      6       10     4       9

該表有 35 列和大約 12k 條記錄(意味著大約 500k 個值)并且正在不斷添加和修改.

The table has 35 columns and around 12k records (meaning around 500k values) and is being added to and amended constantly.

我正在嘗試將其轉換為:

I am trying to transpose this in a view into:

Row ID  Year  Period  Val
100     C     1       10
100     C     2       5
100     C     3       8
100     C     4       9
100     N     1       11
100     N     2       12
100     N     3       5
100     N     4       6

到目前為止,我已設法使用此查詢將其拆分為單個值:

So far I have managed to split it out into single values using this query:

SELECT Row ID, YP, Val

FROM (SELECT Row ID
    , QtyC1 AS C1
    , QtyC2 AS C2
    , QtyC3 AS C3
    , QtyC4 AS C4
    , QtyN1 AS N1
    , QtyN2 AS N2
    , QtyN3 AS N3
    , QtyN4 AS N4

FROM MyTable
) SUB
UNPIVOT (Val FOR YP IN (C1,C2,C3,C4,N1,N2,N3,N4)) AS PVT

這給了我一個單一的識別值(例如 C1),但我如何拆分它以便我有一個數(shù)字句點和一個年份的單個字符(1C)?

This is getting me a single identifying value (eg C1) but how can I split it so I have a numeric period and a single character for the year (1 and C)?

我可以看到可能只是將字符串分成兩部分,但如果可能的話,我希望有一種更簡潔的方法.

I can see it might be possible just splitting up the string into two parts but I was hoping for a cleaner way if possible.

推薦答案

為什么這看起來不干凈?

Why would this seem unclean?

SELECT Row ID, left(YP, 1) as year, cast(right(yp, 1) as int) as period, Val
FROM (SELECT Row ID
    , QtyC1 AS C1
    , QtyC2 AS C2
    , QtyC3 AS C3
    , QtyC4 AS C4
    , QtyN1 AS N1
    , QtyN2 AS N2
    , QtyN3 AS N3
    , QtyN4 AS N4
FROM MyTable
) SUB
UNPIVOT (Val FOR YP IN (C1,C2,C3,C4,N1,N2,N3,N4)) AS PVT

這篇關于使用 UNPIVOT 將列轉換為行的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網(wǎng)!

【網(wǎng)站聲明】本站部分內(nèi)容來源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問題,如果有圖片或者內(nèi)容侵犯了您的權益,請聯(lián)系我們刪除處理,感謝您的支持!

相關文檔推薦

Converting Every Child Tags in to a Single Column with multiple Delimiters -SQL Server (3)(將每個子標記轉換為具有多個分隔符的單列-SQL Server (3))
How can I create a view from more than one table?(如何從多個表創(chuàng)建視圖?)
Create calculated value based on calculated value inside previous row(根據(jù)前一行內(nèi)的計算值創(chuàng)建計算值)
How do I stack the first two columns of a table into a single column, but also pair third column with the first column only?(如何將表格的前兩列堆疊成一列,但也僅將第三列與第一列配對?) - IT屋-程序員軟件開發(fā)技
Recursive t-sql query(遞歸 t-sql 查詢)
Convert Month Name to Date / Month Number (Combinations of Questions amp; Answers)(將月份名稱轉換為日期/月份編號(問題和答案的組合))
主站蜘蛛池模板: 日本色综合 | 成年免费大片黄在线观看岛国 | 免费av直接看 | 成人免费高清 | 精品国产精品 | 国产精品视频网 | 中文字幕一区在线观看视频 | a中文在线视频 | 国产电影一区二区 | 一级免费a | 免费看黄色视屏 | 91国产精品在线 | 欧美一级一区 | 欧美在线看片 | 一区二区三区不卡视频 | 五月婷婷激情 | 国产精品99久久免费观看 | 欧美日韩高清在线一区 | 精品国产一区二区三区久久久蜜月 | 国产精品国产a级 | 亚洲免费人成在线视频观看 | 国产伦精品一区二区三区精品视频 | 国产人成在线观看 | 国产91色在线 | 亚洲 | 九一国产精品 | 国产美女视频黄 | 免费国产视频 | 国产乱码精品1区2区3区 | 懂色中文一区二区三区在线视频 | 九色av| 国产精品99免费视频 | 日韩高清一区 | 国产精品亚洲一区二区三区在线观看 | 国产欧美精品 | 天堂av中文在线 | 免费黄色的视频 | 国产99久久 | 久久一区二区免费视频 | 亚洲黄色网址视频 | 91精品久久久久久久久久小网站 | 视频在线观看亚洲 |