Sql 交叉应用与取消应用

Sql 交叉应用与取消应用,sql,sql-server,unpivot,cross-apply,Sql,Sql Server,Unpivot,Cross Apply,我发现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,

我发现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)

不要使用
,而是使用
选择

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);

请注意,标签是独立的。也就是说,您不能组合多个标记来创建单个概念。标记
[sql]
[server]
一起与单个
[sql server]
标记不同。务必阅读选择标签时出现的说明!很抱歉,我没有足够的声誉来加入交叉申请。我不知道是什么让你认为你需要声誉来使用这个标签。您只需要一定级别的代表即可创建标记,并且已存在。谢谢。你对我的问题有答案吗?