交叉申请与UNPIVOT

Cas*_*ian 3 sql sql-server unpivot cross-apply

我发现UNPIVOT能够自动排除具有NULL值的字段.但是,CROSS APPLY-VALUES方法无法做到这一点.有谁知道如何自动从CROSS APPLY-VALUES中排除NULL值字段?假设,如果字段Field3和Field4包含NULL值,则将其排除.

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)
Run Code Online (Sandbox Code Playgroud)

Gor*_*off 8

而不是使用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);
Run Code Online (Sandbox Code Playgroud)