亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

SQL行轉(zhuǎn)列和列轉(zhuǎn)行代碼詳解

2024-08-31 01:05:12
字體:
供稿:網(wǎng)友

行列互轉(zhuǎn),是一個經(jīng)常遇到的需求。實現(xiàn)的方法,有case when方式和2005之后的內(nèi)置pivot和unpivot方法來實現(xiàn)。
在讀了技術內(nèi)幕那一節(jié)后,雖說這些解決方案早就用過了,卻沒有系統(tǒng)性的認識和總結過。為了加深認識,再總結一次。
行列互轉(zhuǎn),可以分為靜態(tài)互轉(zhuǎn),即事先就知道要處理多少行(列);動態(tài)互轉(zhuǎn),事先不知道處理多少行(列)。

--創(chuàng)建測試環(huán)境USE tempdb;GOIF OBJECT_ID('dbo.Orders') IS NOT NULL DROP TABLE dbo.Orders;GOCREATE TABLE dbo.Orders( orderid  int    NOT NULL PRIMARY KEY NONCLUSTERED, orderdate datetime  NOT NULL, empid   int    NOT NULL, custid  varchar(5) NOT NULL, qty    int    NOT NULL);CREATE UNIQUE CLUSTERED INDEX idx_orderdate_orderid ON dbo.Orders(orderdate, orderid);INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty) VALUES(30001, '20020802', 3, 'A', 10);INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty) VALUES(10001, '20021224', 1, 'A', 12);INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty) VALUES(10005, '20021224', 1, 'B', 20);INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty) VALUES(40001, '20030109', 4, 'A', 40);INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty) VALUES(10006, '20030118', 1, 'C', 14);INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty) VALUES(20001, '20030212', 2, 'B', 12);INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty) VALUES(40005, '20040212', 4, 'A', 10);INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty) VALUES(20002, '20040216', 2, 'C', 20);INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty) VALUES(30003, '20040418', 3, 'B', 15);INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty) VALUES(30004, '20020418', 3, 'C', 22);INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty) VALUES(30007, '20020907', 3, 'D', 30);GO

行轉(zhuǎn)列-靜態(tài)方案:

--行轉(zhuǎn)列的靜態(tài)方案一:CASE WHEN,兼容sql2000select custid,sum(case when YEAR(orderdate)=2002 then qty end) as [2002],sum(case when YEAR(orderdate)=2003 then qty end) as [2003],sum(case when YEAR(orderdate)=2004 then qty end) as [2004]from ordersgroup by custid;GO--行轉(zhuǎn)列的靜態(tài)方案二:PIVOT,sql2005及以后版本select *from (select custid,YEAR(orderdate) as years,qty from orders) as ordpivot(sum(qty) for years in([2002],[2003],[2004]))as pGO

行轉(zhuǎn)列-動態(tài)方案:加入了xml處理和SQL注入預防判斷

--既然是用到了動態(tài)SQL,就有一個老話題:SQL注入。建一個注入性字符的判斷函數(shù)。CREATE FUNCTION [dbo].[fn_CheckSQLInjection]( @Col nvarchar(4000))RETURNS BIT --如果存在可能的注入字符返回true,反之返回falseASBEGINDECLARE @result bit; IF    UPPER(@Col) LIKE UPPER(N'%0x%') OR UPPER(@Col) LIKE UPPER(N'%;%') OR UPPER(@Col) LIKE UPPER(N'%''%') OR UPPER(@Col) LIKE UPPER(N'%--%') OR UPPER(@Col) LIKE UPPER(N'%/*%*/%') OR UPPER(@Col) LIKE UPPER(N'%EXEC%') OR UPPER(@Col) LIKE UPPER(N'%xp_%') OR UPPER(@Col) LIKE UPPER(N'%sp_%') OR UPPER(@Col) LIKE UPPER(N'%SELECT%') OR UPPER(@Col) LIKE UPPER(N'%INSERT%') OR UPPER(@Col) LIKE UPPER(N'%UPDATE%') OR UPPER(@Col) LIKE UPPER(N'%DELETE%') OR UPPER(@Col) LIKE UPPER(N'%TRUNCATE%') OR UPPER(@Col) LIKE UPPER(N'%CREATE%') OR UPPER(@Col) LIKE UPPER(N'%ALTER%') OR UPPER(@Col) LIKE UPPER(N'%DROP%') SET @result=1 ELSE SET @result=0 return @resultENDGO--行轉(zhuǎn)列的動態(tài)方案一:CASE WHEN,兼容sql2000DECLARE @T TABLE (years INT NOT NULL PRIMARY KEY);INSERT INTO @T SELECT DISTINCT YEAR(orderdate) from orders;DECLARE @Y INT;SET @Y=(SELECT MIN(years) from @T);DECLARE @SQL NVARCHAR(4000)=N'';WHILE @Y IS NOT NULLBEGIN SET @SQL=@SQL+N',sum(case when YEAR(orderdate)='+CAST(@Y AS NVARCHAR(4)) +N' then qty end) as '+QUOTENAME(@Y); SET @Y=(SELECT MIN(years) from @T where years>@Y);ENDIF dbo.fn_CheckSQLInjection(@SQL)=0SET @SQL=N'SELECT custid'+@SQL+N' FROM orders group by custid'PRINT @SQLEXEC sp_executesql @SQLGO--行轉(zhuǎn)列的動態(tài)方案二:PIVOT,sql2005及以后版本DECLARE @T TABLE (years INT NOT NULL PRIMARY KEY);INSERT INTO @T SELECT DISTINCT YEAR(orderdate) from orders;DECLARE @Y INT;SET @Y=(SELECT MIN(years) from @T);DECLARE @SQL NVARCHAR(4000)=N'';  --這里使用了xml處理來處理類組字符串SET @SQL=STUFF((SELECT N','+QUOTENAME(years) FROM @T FOR XML PATH('')),1,1,N'');IF dbo.fn_CheckSQLInjection(@SQL)=0SET @SQL=N'select * from (select DISTINCT custid,YEAR(orderdate) as years,qty from orders) as ordpivot(sum(qty) for years in('+@SQL+N'))as p';PRINT @SQL;EXEC SP_EXECUTESQL @SQL;GO

列轉(zhuǎn)行:

--列轉(zhuǎn)行的靜態(tài)方案:UNPIVOT,sql2005及以后版本SELECT * FROM dbo.pvtCustOrdersSELECT custid,years,qtyfrom dbo.pvtCustOrdersunpivot(qty for years in([2002],[2003],[2004]))as upGO--列轉(zhuǎn)行的動態(tài)方案:UNPIVOT,sql2005及以后版本--因為行是動態(tài)所以這里就從INFORMATION_SCHEMA.COLUMNS視圖中獲取列來構造行,同樣也使用了XML處理。DECLARE @SQL NVARCHAR(4000)=N'';SET @SQL=STUFF((SELECT N','+QUOTENAME(COLUMN_NAME ) FROM INFORMATION_SCHEMA.COLUMNSWHERE ORDINAL_POSITION>1 AND TABLE_NAME='PvtCustOrders'FOR XML PATH('')),1,1,N'')SET @SQL=N'SELECT custid,years,qty     from dbo.pvtCustOrders     unpivot(qty for years in('+@SQL+'))as up';PRINT @SQL;EXEC SP_EXECUTESQL @SQL;

總結

以上就是本文關于SQL行轉(zhuǎn)列和列轉(zhuǎn)行代碼詳解的全部內(nèi)容,希望對大家有所幫助。有什么問題可以隨時留言,小編會及時回復大家的。感謝朋友們對VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關教程知識閱讀請移步到MSSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
www.国产自拍| www.我爱av| 91视频在线看| h视频在线观看免费完整版| 久久久精品在线| 5566日本婷婷色中文字幕97| 岛国片av在线| 亚洲av无码一区二区三区人| 欧美69xxxx| 性活交片大全免费看| 男女爱爱免费网站| 国产精品羞羞答答在线观看| 色欧美片视频在线观看在线视频| 国产ts变态重口人妖hd| 四虎国产精品成人永久免费影视| 视频一区在线播放| 亚洲精品一线| 波多野结衣中文字幕在线播放| 欧美美女福利视频| www.久久久久久久久久久| 天天综合久久综合| 精品一区二区三| 久久精品午夜| 最新精品视频在线| 欧美午夜18电影| 亚洲成人激情社区| 国产伦一区二区三区色一情| 在线观看精品自拍视频| 精品人妻一区二区三区免费| 国产在线视频2019最新视频| 中文字幕资源网在线观看免费| 成人免费观看在线网址| 在线国产小视频| 三级网站免费观看| 一区二区国产在线观看| www.久久久久爱免| 9999在线观看| 最新国产精品久久精品| 九色porny丨首页在线| 国产精品成久久久久| 国产又黄又大又粗的视频| 九色网友自拍视频手机在线| 在线观看免费不卡av| 欧美在线观看你懂的| 亚洲线精品久久一区二区三区| 91精品国产欧美一区二区18| 美洲精品一卡2卡三卡4卡四卡| 欧美女孩性生活视频| 天堂av一区二区| 久久久精品五月天| 午夜精品久久久久久久爽| 亚洲国产高清视频| 91国产福利在线| 性一爱一乱一交一视频| 午夜在线视频观看日韩17c| 欧美另类激情| 国产成人福利网站| 中文字幕在线观看1| 日韩小视频在线观看专区| 激情乱色小说视频| 日韩欧美国产一区二区三区| 校园春色欧美| 国产911网站| 性感av在线播放| 免费观看美女裸体网站| 一本在线高清不卡dvd| 污片在线观看一区二区| 亚洲深夜福利在线观看| 性欧美1819sex性高清| 一本大道av伊人久久综合| 在线看日韩欧美| 日韩a一级欧美一级| 亚洲精品久久久久中文字幕二区| 国产精品久久久久蜜臀| 久久久久亚洲av无码专区体验| 亚洲欧美另类国产| 精品视频免费看| 在线日韩欧美| 黄色一级大片免费| 亚洲乱码国产乱码精品精大量| 情侣偷拍对白清晰饥渴难耐| 强迫凌虐淫辱の牝奴在线观看| 综合网在线视频| 免费理论片在线观看播放老| 米奇四色影视| 亚洲欧美国产一本综合首页| 男女视频一区二区三区| 美女av免费观看| 久久国产精品网| 99精品视频国产| 亚洲日日夜夜| 久久综合桃花网| 国产精品亚洲第五区在线| 2024亚洲男人天堂| 中文字幕在线乱| 正在播放一区二区三区| 日本在线人成| 香蕉久久久久久av成人| 成人黄色小视频在线观看| 九九九伊在线综合永久| 91好吊色国产欧美日韩在线| 国产农村妇女毛片精品久久麻豆| 欧美人一级淫片a免费播放| 精品免费在线视频| 青青草原国产在线观看| 国产精品2023| 任我爽在线视频精品一| 国产美女精品人人做人人爽| 国产精品九九九九九九| 麻豆一区二区三区视频| 免费av网站在线看| 精品乱子伦一区二区三区| 99精品在线免费观看| 欧美成人精品欧美一级| 26uuu亚洲| 国产三级视频在线播放| 福利资源在线观看| 国产精品成人播放| 成人资源视频网站免费| 98精品在线视频| 日本欧美亚洲| 欧美主播一区二区三区美女 久久精品人| 日本韩国欧美精品大片卡二| 精品无码人妻一区二区三| 老熟妇精品一区二区三区| 最新亚洲人成网站在线观看| 正在播放国产精品| 亚洲黄色网址| 高h震动喷水双性1v1| 狠狠做六月爱婷婷综合aⅴ| 国产午夜精品免费一区二区三区| 国产专区精品| 中文国语毛片高清视频| 伊人久久噜噜噜躁狠狠躁| 国产chinasex对白videos麻豆| 日韩不卡一二三| 亚洲欧美久久久久一区二区三区| 国产嫩草影院久久久久| 亚洲人成小说网站色在线| 99在线免费视频| 国产在线精品视频| 亚洲人成在线播放网站岛国| 精品一区二区中文字幕| 超碰在线人人| 蜜桃久久精品成人无码av| 国产免费内射又粗又爽密桃视频| 国产人妻精品午夜福利免费| 国产又粗又长又爽又黄的视频| 都市激情亚洲色图| 亚洲精品乱码久久久久久| 一区二区亚洲欧洲国产日韩| 国产丝袜一区二区三区| 欧美一级生活片| 国产一区二区黑人欧美xxxx| 亚洲精品一区二区三区四区| 91传媒免费视频| 91国模少妇一区二区三区| 亚洲三级中文字幕| 正在播放国产对白害羞| 91丨九色丨蝌蚪丨老版| 国产suv精品一区二区6| 国产日韩av在线播放| 久久久久久蜜桃| 97人洗澡人人免费公开视频碰碰碰| 欧美影院视频| 一区二区三区四区高清视频| 搜索黄色一级片| 中文一区一区三区高中清不卡免费| 亚洲国模精品私拍| 日本在线观看a| 日韩精品中文字幕在线| 九九精品在线视频| 国产精品一区二区在线播放| 一区二区成人在线视频| 国产亚洲福利一区| 粉嫩嫩av羞羞动漫久久久| 无码 制服 丝袜 国产 另类| 免费看成年视频网页| 伊人网综合视频| 午放福利视频在线播放| 91社区在线观看| 亚洲国产午夜精品| 成人免费在线一区二区三区| 日韩国产伦理| 美女视频黄的免费| 97在线观看免费观看| 黄色片免费网址| freehdxxxx| 国产精品美日韩| 午夜精品久久久久久久蜜桃app| 激情亚洲一区二区三区四区| 午夜精品福利在线视频| 高h放荡受浪受bl| www亚洲精品| 成年网站在线免费观看| 精品女同一区二区三区在线播放| 日本免费视频| 黄色永久免费网站| 九九热r在线视频精品| 亚洲中文一区二区三区| 亚洲一区美女视频在线观看免费| 91免费看`日韩一区二区| 亚洲精品久久久久久久蜜桃| 成人a v视频| 国产一区二区三区在线观看| 国产主播一区二区三区四区| 亚洲成人激情综合网| 老女人性淫交视频| 日韩久久精品一区二区三区| 欧美zozo另类异族| 国产午夜一区二区| 永久免费看mv网站入口| 美女黄色丝袜一区| 91在线精品播放| 国产黄色大片在线观看| 亚洲午夜在线| 中文字幕乱在线伦视频乱在线伦视频| 中文字幕精品—区二区| 亚洲熟女综合色一区二区三区| 欧美成人一区二免费视频软件| 国产美女av在线| 九九热播视频在线精品6| 欧美综合天天夜夜久久| 欧美激情视频三区| 麻豆av在线免费观看| 亚洲国产综合91精品麻豆| 18禁网站免费无遮挡无码中文| 中国女人内谢69xxxx免费视频| www.久久视频| 欧美日韩在线观看一区二区| 国产裸舞福利在线视频合集| 成人免费网站在线看| 国产精品久久亚洲不卡| 四虎影院免费在线| 久久综合精品一区| 添女人荫蒂视频| 久久午夜无码鲁丝片| 日韩制服诱惑| 欧美偷拍综合| 亚洲精品视频在线免费| 久久99影院| 国产成人av自拍| 欧美高清hd18日本| 青娱乐自拍偷拍| 婷婷一区二区三区| 可以免费观看的黄色网址| 久久精品www人人爽人人| 亚洲天堂免费在线| 国产精品久久久久久9999| 欧美午夜www高清视频| 欧洲vodafonewi精品| 国产精品一在线观看| 欧美日韩在线三级| 亚洲欧美成人精品| 国产真人真事毛片| 国精产品一区一区三区视频| 国产精品入口夜色视频大尺度| 国产香蕉尹人视频在线| 国产高清精品二区| 午夜免费一级片| 日韩欧美中字| 蜜臀久久99精品久久久久久宅男| 韩国一区二区视频| 成人黄动漫网站| 日韩精品一区二区三区国语自制| 在线免费观看h视频| 天堂社区日本电影超碰| 亚州欧美日韩中文视频| 国内精品久久久久久影院老狼| 亚洲一区美女视频在线观看免费| 国产成人综合在线播放| 中文字幕亚洲综合久久五月天色无吗''| 桃乃木香奈av在线| 国产精品伦理久久久久久| 免费电影一区| 日韩视频免费看| av综合在线观看| yw在线观看| 亚洲成人激情在线观看| 国产又色又爽又黄的| 一级成人国产| 污视频在线免费观看一区二区三区| 好看的黄色网址| 天天草夜夜操| 久久精品国产精品国产精品污| 国产精品久久久网站| 看黄在线观看| 日韩亚洲欧美综合| 操她视频网站| 欧美精品国产精品| 中文字幕在线不卡一区| 蜜桃成人在线视频| 国内精品伊人久久久久av一坑| 成人亚洲精品777777大片| 宅男噜噜噜66一区二区66| 2019国产精品自在线拍国产不卡| 一级黄色录像在线观看| 欧美深性狂猛ⅹxxx深喉| 欧美日韩亚洲成人| 国产又爽又黄又刺激的软件| 国产又粗又黄又爽| 国产精品毛片在线看| 久久久久久久国产精品| 中文字幕亚洲一区| 9l国产精品久久久久麻豆| 亚洲激情黄色| 一区二区亚洲| 人与牲动交xxxxbbb| 97久久综合精品久久久综合| 国产美女精品视频国产| 日韩精品一区二区三| 久久久久久久久久久影视| 国产激情一区二区三区在线观看| 久久久国产视频91| 亚洲一区二区成人| 91香蕉视频在线观看| 夜夜春很很躁夜夜躁| 日韩在线高清视频| 亚洲激情在线观看视频免费| 中文在线资源新版官网| 欧美天天在线| 免费电影一区二区三区| 国产探花在线视频| 日本黄网站色大片免费观看| 欧美激情一区二区三区免费观看| 久久免费国产视频| 国产美女撒尿一区二区| 国产精品扒开腿做爽爽爽视频|