繁体   English   中英

从同一表的1个主列创建2列

[英]creating 2 columns from 1 main column in the same table

SELECT TOP 1000 [Value]                       
FROM [OnlineQnres].[dbo].[tmp_DataSets]
WHERE [VariableID] in ('1')
UNION ALL
SELECT TOP 1000 [Value]
FROM [OnlineQnres].[dbo].[tmp_oDataSets]
WHERE [VariableID] in ('4')

提供更多更新的详细信息

大家好,我在上面使用UNION ALL进行了选择查询。 tmp_datasets表中有一列称为Value和VariableID的列。 我需要创建2个单独的列,并将其命名为val1,variableID为1,如果valID为4,则命名为val2。如果我使用UNION ALL,它会创建2000条记录,其中前1000条为val1记录,接下来的1000条为val2记录,但不会分开分成2列。 如上所述,我如何将此值列分为2个单独的列。

我有2栏

  • VALUE ,其值为TEST56,TEST57,230,245
  • VARIABLEID = 1和4

  • TEST56和TEST57在变量id == 1下

  • 230和245在变量id == 4下

因此,基于上面的示例,我想创建一个视图,其中如果variableid == 1,则有两列分别称为val1和val2(如果变量id == 4)。

所以应该看起来像这样

  • val1 =应该显示test56和test57
  • val2 =应该显示230和245

提前致谢

几个案例陈述应该可以满足我的要求:

SELECT TOP 1000
[Variable] 
CASE [VariableID]
  WHEN 1 THEN 1
  ELSE 0
END AS Val1,     
CASE [VariableID]
  WHEN 4 THEN 1
  ELSE 0
END AS Val2                       
FROM [OnlineQnres].[dbo].[tmp_DataSets]
WHERE [VariableID] = 1 or [VariableID] = 4

SQLFiddle链接: http ://sqlfiddle.com/#!6/825f2/8/0

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM