sql 连续活跃天数

yizhihongxing

1. 背景

已知数据集为:
sql 连续活跃天数
目的:
计算每个uid的连续活跃天数,并且每一段活跃期内的开始时间和结束时间

2. 步骤

第一步:处理数据集
处理数据集,使其满足每个uid每个日期只有一条数据。
第二步:以uid为主键,按照日期进行排序,计算row_number.

SELECT  uid
          ,`征信查询日期`
          ,ROW_NUMBER() OVER(PARTITION BY uid ORDER BY `征信查询日期` ASC) AS `rn`
          ,first_value(`征信查询日期`)over(PARTITION BY uid ORDER BY `征信查询日期` ASC) `fir`
          ,first_value(`征信查询日期`)over(PARTITION BY uid ORDER BY `征信查询日期` desc) `las`
FROM   input

sql 连续活跃天数

两个关键点:

  1. 序号rn可以看做一直活跃的情况下,活跃日期最大值和活跃日期最小值之间的天数差。那么,日期最大值与日期最小值之差如果不等于序号,就表明中间有不连续。
  2. 用'征信查询日期' - rn 可以计算一列"关键列",连续时间段内,它的关键列值是一样的
select *,DATE_SUB(`征信查询日期`,`rn`) as `关键列` from (
SELECT  uid
          ,`征信查询日期`
          ,ROW_NUMBER() OVER(PARTITION BY uid ORDER BY `征信查询日期` ASC) AS `rn`
          ,first_value(`征信查询日期`)over(PARTITION BY uid ORDER BY `征信查询日期` ASC) `fir`
          ,first_value(`征信查询日期`)over(PARTITION BY uid ORDER BY `征信查询日期` desc) `las`
FROM   input)

sql 连续活跃天数
第三步:以uid和关键列作为主键。

select uid, `关键列`,count(*) as `连续活跃天数`, min(`征信查询日期`) as `活跃开始时间`, max(`征信查询日期`) as `活跃结束时间` from (
select *, DATE_SUB(`征信查询日期`,`rn`) as `关键列` from (
SELECT  uid
          ,`征信查询日期`
          ,ROW_NUMBER() OVER(PARTITION BY uid ORDER BY `征信查询日期` ASC) AS `rn`
          ,first_value(`征信查询日期`)over(PARTITION BY uid ORDER BY `征信查询日期` ASC) `fir`
          ,first_value(`征信查询日期`)over(PARTITION BY uid ORDER BY `征信查询日期` desc) `las`
FROM   input
  ) )group by uid, `关键列`

sql 连续活跃天数

原文链接:https://www.cnblogs.com/tian1022/p/17310496.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:sql 连续活跃天数 - Python技术站

(0)
上一篇 2023年4月17日
下一篇 2023年4月17日

相关文章

  • MySQL注释:单行注释和多行注释使用方法

    MySQL注释可以帮助我们在SQL语句中添加注释,提高代码的可读性和维护性。在MySQL中,注释分为单行注释和多行注释两种。 单行注释 单行注释以"#"或"–"开头,直到该行的结尾为止,该行后面的代码都不会被执行。 例如: — 这是单行注释 # 这也是单行注释 SELECT * FROM `users`; — 该…

    MySQL 2023年3月9日
    00
  • MySQL Like模糊查询速度太慢如何解决

    当进行MySQL Like模糊查询时,如果数据量庞大,查询速度可能会变得非常缓慢,这时我们需要寻找一些优化方法来提高查询效率。下面是一些解决方法: 1. 使用索引 如果您要查询的字段经常用于模糊查询,那么应该为该字段添加索引。可以使用如下语法为指定的列添加索引: ALTER TABLE table_name ADD INDEX index_name (col…

    MySQL 2023年5月19日
    00
  • MySQL锁监控

    MySQL锁监控是指通过监控MySQL数据库中的锁信息,了解系统中正在发生的锁冲突情况,从而识别潜在的性能瓶颈或问题,并采取相应的措施进行优化和解决。 具体来说,MySQL锁监控主要通过以下几个方面来实现: 了解锁类型和锁范围:通过监控MySQL数据库中不同类型的锁(如共享锁、排他锁等)以及锁的范围(如行锁、表锁等),可以判断锁的具体情况和影响范围。 分析锁…

    MySQL 2023年3月10日
    00
  • 如何解决安装MySQL5.0后出现1607异常

    如何解决安装MySQL5.0后出现1607异常 问题描述 在安装Mysql5.0的过程中,可能会遇到1607异常,异常如下所示: Error 1607: Unable to install InstallShield Scripting Runtime 问题原因 该问题的主要原因是InstallShield脚本运行时没有正确安装或已损坏。 解决方案 方案一:…

    MySQL 2023年5月18日
    00
  • MySQL中一条update语句是如何执行的

    MySQL中的一条update语句的执行过程可以分为以下步骤: 1.分析语句: MySQL服务器首先会对update语句进行解析,并检查语法和语义是否正确。如果有语法错误或缺少操作权限,服务器将拒绝执行该语句。 2.查询优化: 一旦语句被分析,MySQL服务器会进行查询优化,以确定执行查询的最佳方式。这个过程包括选择索引,重新排列关联表的顺序等。为了提高查询…

    MySQL 2023年5月19日
    00
  • Mysql之INTERVAL与DATE_SUB与EXTRACT函数的使用

    1. INTERVAL INTERVAL代表的是时间间隔MySQL中的时间间隔类型有如下几种:       1.1 利用INTERVAL做时间的加减法 示例: 加法:SQL>SELECT DATE ‘2018-11-01′ + INTERVAL ’10 11’ DAY_HOUR;结果:2018-11-11 11:00:00减法:SQL> sele…

    MySQL 2023年4月13日
    00
  • 分析MySQL抛出异常的几种常见解决方式

    分析MySQL抛出异常的几种常见解决方式 MySQL 是一种常用的数据库管理系统,但在使用 MySQL 时也会遇到一些常见的异常情况。以下是解决这些异常情况的几种方法: 1. 处理连接超时异常 连接超时是一种非常常见的异常情况。当使用 MySQL 连接时,如果在指定的时间内没有接收到响应,则会抛出连接超时异常。处理连接超时异常的一种方法是在连接时使用 con…

    MySQL 2023年5月18日
    00
  • 详解MySQL登录和退出服务器方法

    MySQL是一种关系型数据库管理系统,具有开源、高效、稳定和安全等特点,被广泛应用于Web开发和数据处理领域。为了使用MySQL,需要先登录数据库服务器,操作完成后再退出服务器。本文将详细介绍MySQL登录和退出服务器方法。 MySQL登录服务器方法 MySQL服务器通常在Linux或Windows操作系统上运行,需要使用MySQL客户端工具进行连接。MyS…

    MySQL 2023年3月10日
    00
合作推广
合作推广
分享本页
返回顶部