sql - 交叉应用与 UNPIVOT

标签 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)

最佳答案

不要使用 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);

关于sql - 交叉应用与 UNPIVOT,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23600541/

相关文章:

amazon-redshift - Redshift-多列至行(不可透视)

sql - 将周工资信息分为日工资信息

mysql - SQL UPDATE 语句中涉及子查询的错误

mysql - 使用 'IF' 检测 mysql 更新查询中的 NULL

sql - 是否可以在 Azure Web 角色中运行 SQL Express?

sql-server - 具有高可用性组的多宿主 SQL Server

php - 从嵌套数组中获取 SQL 列值

c# - 如何从存储过程中将列数据作为逗号分隔的字符串发送?

sql-server - 在Sql Server中的单例语句中组合多个条件