HIVE、ORACLE 等数据库 SQL 连续数据的统计

在 mysql 中逻辑演化过程

HIVE、ORACLE 等数据库 SQL 连续数据的统计

HIVE、ORACLE 等数据库 SQL 连续数据的统计

SELECT 
ip,`type`, CONCAT(MIN(tt), '-', MAX(tt)) mindivmax
FROM (
SELECT 
ip, 
`type`, 
tt, 
CASE WHEN @iptype = (ip || '-' || `type`) THEN (
@ind
)
ELSE (
@ind:[email protected] + 1
) END flag,
@iptype := CONCAT(ip,'-',`type`) iptype
FROM 
cc, (SELECT @ind:=0) ind, (SELECT @iptype='') iptype
) ta
GROUP BY ta.iptype, ta.flag ORDER BY ip, mindivmax

在有 over 函数的数据库中

HIVE、ORACLE 等数据库 SQL 连续数据的统计

HIVE、ORACLE 等数据库 SQL 连续数据的统计

SELECT ip, type,min(tm), max(tm) FROM

(
  SELECT 
    ID,
    ip,
    type,
    tm,
    row_number() OVER(ORDER BY id) - row_number() OVER (PARTITION BY ip,type ORDER BY ID) x 
  FROM my 

GROUP BY ip,type, x 


重新整理: 

HIVE、ORACLE 等数据库 SQL 连续数据的统计

HIVE、ORACLE 等数据库 SQL 连续数据的统计

SELECT 
  min(id) minId, ip,min(time) || '-' || max(time) time
FROM
(
  SELECT 
    id,
    ip,
    time,
    row_number() OVER(ORDER BY id) - row_number() OVER (PARTITION BY ip ORDER BY ID) x 
  FROM visit 

GROUP BY 
      ip, x 
order by 
      minId




相关文章:

  • 2021-06-25
  • 2021-08-29
  • 2021-07-23
  • 2021-04-30
  • 2022-01-01
  • 2022-12-23
  • 2021-10-02
猜你喜欢
  • 2022-12-23
  • 2021-12-20
  • 2021-12-28
  • 2021-11-27
  • 2021-11-22
  • 2022-02-05
相关资源
相似解决方案