我发现UNPIVOT能够自动排除具有空值的字段。然而,交叉应用-值方法不能做到这一点。有人知道如何从交叉应用值中自动排除空值字段吗?比方说,如果字段Field3和Field4包含空值,则排除它们。
SELECT
E.FieldA,
E.FieldB,
E.FieldC,
DBParam.Display,
DBParam.Value
INTO DBParam
FROM
Map_Data AS E
CROSS APPLY (VALUES (Field1, 'Field1'),
(Field2, 'Field2'),
(Field3, 'Field3'),
(Field4, 'Field4')
) AS DBParam(Value, Display)发布于 2014-05-12 05:06:34
不要使用VALUES,而是使用SELECT
SELECT E.FieldA, E.FieldB, E.FieldC,
DBParam.Display, DBParam.Value
INTO DBParam
FROM Map_Data E CROSS APPLY
(SELECT Value, Display
FROM (SELECT Field1 as Value, 'Field1' as Display UNION ALL
SELECT Field2, 'Field2' UNION ALL
SELECT Field3, 'Field3' UNION ALL
SELECT Field4, 'Field4'
) vd
WHERE Value is not null
) as DBParam(Value, Display);https://stackoverflow.com/questions/23600541
复制相似问题