我在访问中有以下表格(odbc链接到实际的mssql表)
我可以创建表的交叉表查询,将其转换为此格式
以下是访问中生成的sql:
TRANSFORM First(dbo_85137_PHY_Long_MP.[StatColumnValue]) AS FirstOfStatColumnValue
SELECT dbo_85137_PHY_Long_MP.[StatDate]
FROM dbo_85137_PHY_Long_MP
GROUP BY dbo_85137_PHY_Long_MP.[StatDate]
PIVOT dbo_85137_PHY_Long_MP.[StatColumnName];
我试图在mssql中创建相同的sql无效(尝试创建视图)
答案 0 :(得分:5)
由于您使用的是SQL Server,因此您需要使用PIVOT运算符。您可以通过静态PIVOT或动态PIVOT两种方式执行此操作。
静态PIVOT ,表示您将为需要旋转的每列进行编码。因为看起来你有很多专栏我怀疑你会想要这样做。但代码与此类似:
create table t1
(
statno int,
statdate datetime,
statcolumnname varchar(50),
statcolumnvalue int
)
insert into t1 values (1, '4/1/2012 12:15:00', 'MPB-1MA.MP00-1MA', 17)
insert into t1 values (1, '4/1/2012 12:15:00', 'MPB-1MA.MP01-1MA', 18)
insert into t1 values (1, '4/1/2012 12:15:00', 'MPB-1MA.MP02-1MA', 18)
insert into t1 values (1, '4/1/2012 12:15:00', 'MPB-1MA.MP03-1MA', 18)
insert into t1 values (1, '4/1/2012 12:15:00', 'MPB-1ME.MP10-1ME', 26)
insert into t1 values (1, '4/1/2012 12:15:00', 'MPB-1ME.MP11-1ME', 2)
insert into t1 values (1, '4/1/2012 12:15:00', 'MPB-1ME.MP12-1ME', 2)
insert into t1 values (1, '4/1/2012 12:15:00', 'MPB-2MC.MP08-2MC', 2)
insert into t1 values (1, '4/1/2012 12:15:00', 'MPB-2MC.MP09-2MC', 22)
insert into t1 values (1, '4/1/2012 12:15:00', 'MPB-2MC.MP0A-2MC', 22)
insert into t1 values (1, '4/1/2012 12:15:00', 'MPB-2MC.MP0B-2MC', 22)
select *
from
(
select statdate, statcolumnname, statcolumnvalue
from t1
) x
pivot
(
min(statcolumnvalue)
for statcolumnname in ([MPB-1MA.MP00-1MA], [MPB-1MA.MP01-1MA], [MPB-1MA.MP02-1MA])
) p
这是一个SQL Fiddle,其中有一个工作示例。
如果您有很多专栏,这将非常麻烦。因此,您还可以使用动态数据透视,这将生成在运行查询时要旋转的列列表。这是代码:
DECLARE @cols AS NVARCHAR(MAX),
@query AS NVARCHAR(MAX);
select @cols = STUFF((SELECT distinct ',' + QUOTENAME(c.statcolumnname)
FROM t1 c
FOR XML PATH(''), TYPE
).value('.', 'NVARCHAR(MAX)')
,1,1,'')
set @query = 'SELECT statdate, ' + @cols + ' from
(
select statdate, statcolumnname, statcolumnvalue
from t1
) x
pivot
(
min(statcolumnvalue)
for statcolumnname in (' + @cols + ')
) p '
execute(@query)
他们两个都会给你相同的结果。