首页 > 解决方案 > 如何根据 SQL 中的唯一标识符为 null 赋值?

问题描述

我正在尝试根据 ID 列将字符串分配给空类别。我想要做的是用基于 ID 的销售代表替换空值。我不一定需要覆盖空值,添加带有调整后的销售名称的列也可以。我在想也许可以根据唯一 ID 使用案例组,但我没有运气。我有一个具有这种结构的表:

样本数据:

ID            SalesRep      Amount  
123           Steve         50.00  
123           Steve         100.00  
123           Steve         150.00   
123           NULL          200.00

456           Dave          25.00  
456           Dave          75.00  
456           Dave          500.00   
456           NULL          300.00

预期结果:

ID            SalesRep      Amount  
123           Steve         50.00  
123           Steve         100.00  
123           Steve         150.00   
123           Steve         200.00

456           Dave          25.00  
456           Dave          75.00  
456           Dave          500.00   
456           Dave          300.00

标签: sqlsql-server-2012nulluniqueidentifier

解决方案


您可以使用窗口函数:

select t.*,
       coalesce(SalesRep,
                max(SalesRep) over (partition by id) as imputed_ SalesRep
               )
from t;

推荐阅读