【问题标题】:T-SQL: Insert in table results of CTET-SQL:在 CTE 的表结果中插入
【发布时间】:2013-10-16 03:22:54
【问题描述】:

我有这个 TSQL 语法:

WITH cte AS(
SELECT Stamps, row_number() over (order by (SELECT 1)) rn from week
unpivot      
(Stamps FOR Day IN ([Sun], [Mon], [Tue], [Wed], [Thu], [Fri], [Sat]) ) AS unpvt )

SELECT Stamps + ': ' +STUFF((SELECT ','+cast(rn as varchar(9)) from cte where Stamps=A.TimeStamps FOR XML PATH('')), 1 , 1 , '' ) from cte A group by Stamps

这给了我每个“邮票”的日期。 例如,如果表是:

S2 | S0 | S0 | S1 | S1 | S3 | S2

结果将是:

S0 : 2,3
S1 : 4,5
S2 : 1,7
S3 : 6

这部分效果很好,但现在我想把这个结果放在一个表格中

点赞Insert Into mytable (S0, S1, S2, S3) = ('2,3','4,5','1,7','6')

但是当我在它之后或之前设置它不起作用。 我该怎么做? 谢谢

【问题讨论】:

  • 您不应该存储逗号分隔的值 - 它们使用起来很尴尬,使编写一般查询变得困难等。看起来您已经使用 @987654325 在列名中嵌入了数据@ - S3,如果它们实际上都代表相同“类型”的数据。

标签: sql-server tsql insert common-table-expression


【解决方案1】:

我想你想把它转回来。这个怎么样:

WITH cte AS(
SELECT Stamps, row_number() over (order by (SELECT 1)) rn from week
unpivot      
(Stamps FOR Day IN ([Sun], [Mon], [Tue], [Wed], [Thu], [Fri], [Sat]) ) AS unpvt 
), cte2 AS (

SELECT Stamps , STUFF((SELECT ','+cast(rn as varchar(9)) 
                             from cte where Stamps=A.[Stamps] FOR XML PATH('')), 1 , 1 , '' ) 
  as DayList
from cte A
group by Stamps
)
INSERT MyTable (S0, S1, S2, S3)
select S0, S1, S2, S3 from cte2
PIVOT
(
Max(DayList)
FOR Stamps IN ([S0], [S1], [S2], [S3])
) AS PivotTable;

SQL 小提琴:http://sqlfiddle.com/#!6/37ff8/2

【讨论】:

  • 它有效,但如果我插入其他值,如 00、02。结果将为空。到目前为止,我还没有找到原因。你有什么建议吗?
  • 在哪里插入其他值?我真的不明白这些“邮票”是什么或你想要完成什么。
猜你喜欢
  • 2015-03-20
  • 1970-01-01
  • 2017-08-31
  • 1970-01-01
  • 2015-05-03
  • 1970-01-01
  • 2020-06-08
  • 1970-01-01
  • 2021-02-19
相关资源
最近更新 更多