在另一列上复制在某些条件下具有空值的列

Posted

技术标签:

【中文标题】在另一列上复制在某些条件下具有空值的列【英文标题】:Replicate the a column which has null values on certain conditions on another column 【发布时间】:2020-05-26 02:45:48 【问题描述】:

使用的数据库是 SQL Server。

我的表中有以下值:

ID  SESSION_ID  UID CREATED_DATE            MESSAGE_TYPE    MESSAGE                 QID
A10001  s1      U1  2020-05-25 06:14:23.430     U       fjdlasjfljdlajfljda         NULL
A10002  s1      U1  2020-05-25 06:14:29.480     B       fjdlasjfljdlajfljda         NULL
A10003  s1      U1  2020-05-25 06:14:32.317     U       fjdlasjfljdlajfljda         NULL
A10004  s1      U1  2020-05-25 06:14:39.297     B       fjdlasjfljdlajfljda         NULL
A10005  s1      U1  2020-05-25 06:14:43.123     B       fjdlasjfljdlajfljda         NULL
A10006  s1      U1  2020-05-25 06:14:47.420     U       fjdlasjfljdlajfljda         NULL
A10007  s1      U1  2020-05-25 06:15:19.237     B       fjdlasjfljdlajfljda         NULL
A10008  s1      U1  2020-05-25 06:15:29.467     B       fjdlasjfljdlajfljda         NULL
A10009  s1      U1  2020-05-25 06:15:29.467     B       fjdlasjfljdlajfljda         NULL
A10010  s2      U1  2020-05-25 06:15:37.040     U       fjdlasjfljdlajfljda         NULL
A10011  s2      U1  2020-05-25 06:15:53.583     B       fjdlasjfljdlajfljda         NULL
A10012  s2      U1  2020-05-25 06:15:56.520     B       fjdlasjfljdlajfljda         NULL
A10013  s3      U2  2020-05-25 06:16:00.213     U       fjdlasjfljdlajfljda         NULL
A10014  s3      U2  2020-05-25 06:16:03.547     B       fjdlasjfljdlajfljda         NULL
A10015  s3      U2  2020-05-25 06:16:06.430     U       fjdlasjfljdlajfljda         NULL

我正在尝试根据以下条件将 Id 的值插入我的 QID 列:

Message_type 为 U - QID 为空 对于所有后续消息类型“B”,QID 将具有来自消息类型为“U”的 ID 列的值

下面是示例输出:

    ID  SESSION_ID  UID CREATED_DATE            MESSAGE_TYPE    MESSAGE                 QID
    A10001  s1      U1  2020-05-25 06:14:23.430     U       fjdlasjfljdlajfljda         NULL
    A10002  s1      U1  2020-05-25 06:14:29.480     B       fjdlasjfljdlajfljda         A10001
    A10003  s1      U1  2020-05-25 06:14:32.317     U       fjdlasjfljdlajfljda         NULL
    A10004  s1      U1  2020-05-25 06:14:39.297     B       fjdlasjfljdlajfljda         A10003
    A10005  s1      U1  2020-05-25 06:14:43.123     B       fjdlasjfljdlajfljda         A10003
    A10006  s1      U1  2020-05-25 06:14:47.420     U       fjdlasjfljdlajfljda         NULL
    A10007  s1      U1  2020-05-25 06:15:19.237     B       fjdlasjfljdlajfljda         A10006
    A10008  s1      U1  2020-05-25 06:15:29.467     B       fjdlasjfljdlajfljda         A10006
    A10009  s1      U1  2020-05-25 06:15:29.467     B       fjdlasjfljdlajfljda         A10006
    A10010  s2      U1  2020-05-25 06:15:37.040     U       fjdlasjfljdlajfljda         NULL
    A10011  s2      U1  2020-05-25 06:15:53.583     B       fjdlasjfljdlajfljda         A10010
    A10012  s2      U1  2020-05-25 06:15:56.520     B       fjdlasjfljdlajfljda         A10010
    A10013  s3      U2  2020-05-25 06:16:00.213     U       fjdlasjfljdlajfljda         NULL
    A10014  s3      U2  2020-05-25 06:16:03.547     B       fjdlasjfljdlajfljda         A10013
    A10015  s3      U2  2020-05-25 06:16:06.430     U       fjdlasjfljdlajfljda         NULL

我尝试过使用row_number()ranking。但没有运气。 请帮我解决这个问题。

【问题讨论】:

向我们展示您的实际尝试,以便我们在此基础上再接再厉。 【参考方案1】:

您可以为此使用窗口函数。我建议使用每次满足 message_type 'U' 来定义组时递增的窗口总和,然后是 first_value()

select
    id, session_id, uid, created_date, message_type, message,
    case when message_type = 'B' 
        then first_value(id) over(partition by grp order by created_date) 
    end qid
from (
    select 
        t.*,
        sum(case when message_type = 'U' then 1 else 0 end) 
            over(order by created_date) grp
    from mytable t
) t

Demo on DB Fiddle

编号 | session_id | uid |创建日期 |消息类型 |留言 |齐德 :----- | :--------- | :-- | :------------------------ | :----------- | :----------------- | :----- A10001 | s1 | U1 | 2020-05-25 06:14:23.430 |你 | fjdlasjfljdlajfljda | A10002 | s1 | U1 | 2020-05-25 06:14:29.480 |乙| fjdlasjfljdlajfljda | A10001 A10003 | s1 | U1 | 2020-05-25 06:14:32.317 |你 | fjdlasjfljdlajfljda | A10004 | s1 | U1 | 2020-05-25 06:14:39.297 |乙| fjdlasjfljdlajfljda | A10003 A10005 | s1 | U1 | 2020-05-25 06:14:43.123 |乙| fjdlasjfljdlajfljda | A10003 A10006 | s1 | U1 | 2020-05-25 06:14:47.420 |你 | fjdlasjfljdlajfljda | A10007 | s1 | U1 | 2020-05-25 06:15:19.237 |乙| fjdlasjfljdlajfljda | A10006 A10008 | s1 | U1 | 2020-05-25 06:15:29.467 |乙| fjdlasjfljdlajfljda | A10006 A10009 | s1 | U1 | 2020-05-25 06:15:29.467 |乙| fjdlasjfljdlajfljda | A10006 A10010 | s2 | U1 | 2020-05-25 06:15:37.040 |你 | fjdlasjfljdlajfljda | A10011 | s2 | U1 | 2020-05-25 06:15:53.583 |乙| fjdlasjfljdlajfljda | A10010 A10012 | s2 | U1 | 2020-05-25 06:15:56.520 |乙| fjdlasjfljdlajfljda | A10010 A10013 | s3 | U2 | 2020-05-25 06:16:00.213 |你 | fjdlasjfljdlajfljda | A10014 | s3 | U2 | 2020-05-25 06:16:03.547 |乙| fjdlasjfljdlajfljda | A10013 A10015 | s3 | U2 | 2020-05-25 06:16:06.430 |你 | fjdlasjfljdlajfljda |

【讨论】:

以上是关于在另一列上复制在某些条件下具有空值的列的主要内容,如果未能解决你的问题,请参考以下文章

SQL Server:对列的每个组值求和(或差),直到在另一列上满足条件

在另一列上分组后查找列值的最大出现次数

如何在具有空值的列上使用`jsonb_set`

选择一列上的值在另一列上具有相同的一组值

如何在另一列中按条件分组的列中查找下一个日期?

在另一列中使用一列中的值