sql列转行

wozaiztam 2013-06-27 02:37:33
代码如下:
SELECT RodNo,TestTime,TestProject,Operator,RecordTime,avgeccentricity,maxeccentricity
FROM
(
SELECT t1.RodNo, t1.TestTime, t1.TestProject, t1.Operator, t1.RecordTime,t2.avgeccentricity,t2.maxeccentricity
FROM PRO_EccentricityInfo t1
LEFT JOIN (select detail_id,round(AVG(eccentricity),3) avgeccentricity,round(MAX(eccentricity),3) maxeccentricity FROM PRO_EccentricityInfo_Details GROUP BY detail_id) t2
ON t1.ID=t2.detail_id
WHERE t1.RodNo='A03S0113-08A'
)T
UNPIVOT
(
avgeccentricity FOR TestProject IN ([偏心率], [芯层不圆度], [预制棒棒径], [预制棒不圆度])
) P


其中:
SELECT t1.RodNo, t1.TestTime, t1.TestProject, t1.Operator, t1.RecordTime,t2.avgeccentricity,t2.maxeccentricity
FROM PRO_EccentricityInfo t1
LEFT JOIN (select detail_id,round(AVG(eccentricity),3) avgeccentricity,round(MAX(eccentricity),3) maxeccentricity FROM PRO_EccentricityInfo_Details GROUP BY detail_id) t2
ON t1.ID=t2.detail_id
WHERE t1.RodNo='A03S0113-08A'

是可以查到数据的


但是整句话就报错:
消息 207,级别 16,状态 1,第 12 行
列名 '偏心率' 无效。
消息 207,级别 16,状态 1,第 12 行
列名 '芯层不圆度' 无效。
消息 207,级别 16,状态 1,第 12 行
列名 '预制棒棒径' 无效。
消息 207,级别 16,状态 1,第 12 行
列名 '预制棒不圆度' 无效。
消息 265,级别 16,状态 1,第 12 行
在 UNPIVOT 运算符中指定的列名 "avgeccentricity" 与 UNPIVOT 参数中现有的列名冲突。
消息 265,级别 16,状态 1,第 12 行
在 UNPIVOT 运算符中指定的列名 "TestProject" 与 UNPIVOT 参数中现有的列名冲突。
消息 8156,级别 16,状态 1,第 13 行
多次为 'P' 指定了列 'avgeccentricity'。


求解释啊
...全文
202 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
风一样的大叔 2013-06-27
  • 打赏
  • 举报
回复
with TB as (
SELECT t1.RodNo, t1.TestTime, t1.TestProject, t1.Operator, t1.RecordTime,t2.eccentricity
FROM  PRO_EccentricityInfo t1
LEFT JOIN (select detail_id,round(AVG(eccentricity),3) eccentricity FROM  PRO_EccentricityInfo_Details GROUP BY detail_id) t2 
ON t1.ID=t2.detail_id
WHERE t1.RodNo='A03S0113-08A'
) 
SELECT RodNo,max(TestTime),max(Operator),max(RecordTime),max(偏心率) 偏心率,max(芯层不圆度) 芯层不圆度,max(预制棒棒径) 预制棒棒径,max(预制棒不圆度) 预制棒不圆度--RodNo,TestTime,Operator,RecordTime,偏心率,芯层不圆度,预制棒棒径,预制棒不圆度
FROM TB 
PIVOT 
(
   max(eccentricity) FOR TestProject IN (偏心率,芯层不圆度,预制棒棒径,预制棒不圆度)
) t3
GROUP BY RodNo
wozaiztam 2013-06-27
  • 打赏
  • 举报
回复
with TB as (
SELECT t1.RodNo, t1.TestTime, t1.TestProject, t1.Operator, t1.RecordTime,t2.avgeccentricity
FROM PRO_EccentricityInfo t1
LEFT JOIN (select detail_id,round(AVG(eccentricity),3) avgeccentricity FROM PRO_EccentricityInfo_Details GROUP BY detail_id) t2
ON t1.ID=t2.detail_id
WHERE t1.RodNo='A03S0113-08A'
)
SELECT RodNo,TestTime,Operator,RecordTime,[偏心率] as [偏心率], [芯层不圆度] as [芯层不圆度],[预制棒棒径] as [预制棒棒径],[预制棒不圆度] as [预制棒不圆度] FROM TB
PIVOT
(
max(avgeccentricity) FOR TestProject IN ([偏心率], [芯层不圆度], [预制棒棒径], [预制棒不圆度])
) P




请问这个怎么变成一行啊,前面的都一样的,GROUP BY RodNo,TestTime,Operator,RecordTime,[偏心率], [芯层不圆度], [预制棒棒径], [预制棒不圆度]
没用啊
wozaiztam 2013-06-27
  • 打赏
  • 举报
回复
貌似错了,是行转列
叶子 2013-06-27
  • 打赏
  • 举报
回复

34,876

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧