嵌套子查询

最近更新时间: 2026-03-13 09:03:00

本文介绍嵌套子查询的语法使用与操作示例。

语法格式

针对一些复杂的统计分析场景,需要先对原始数据进行一次统计分析,再针对该分析结果进行二次统计分析,这时候需要在一个 SELECT 语句中嵌套另一个 SELECT 语句,这种查询方式称为嵌套子查询。

* | SELECT key FROM (subquery)
  • subquery:子查询,需被包裹在括号中。
  • key:需要从子查询中获取哪些字段进行二次统计分析。
  • 支持多层嵌套,不局限于两层。

语法示例

计算当前1小时和昨天同时段的网站访问量比值:
选择查询和分析的时间范围为近1小时,并执行如下查询和分析语句,其中86400表示当前时间减去86400秒(1天)。

* | SELECT compare(PV, 86400) FROM (SELECT count(*) AS PV)
  • SELECT count(*) AS PV为第一层统计分析,针对原始日志统计获得网站访问量 PV。
  • SELECT compare(PV, 86400) FROM为第二层统计分析,针对第一层统计分析的结果,对 PV 进行二次统计,使用 同环比函数compare 获得1天前的网站访问量 PV。

结果为数组:

[1860,1656,1.1231884057971016]
  • 1860表示当前1小时的网站访问量。
  • 1656表示昨天同时段的网站访问量。
  • 1.1231884057971016表示当前1小时与昨天同时段的网站访问量比值。

如需分别获取数组中的元素,则可进一步嵌套查询:

* | 
SELECT compare[1] AS today, compare[2] AS yesterday, compare[3] AS ratio
FROM (
    SELECT compare(PV, 86400) AS compare
    FROM (
        SELECT COUNT(*) AS PV
    )
)

SELECT compare[1] AS today, compare[2] AS yesterday, compare[3] AS ratio FROM 针对 compare 函数的结果,通过数组下标获取其中特定位置的数值。