按最接近的前一个值进行的bigquery左连接
创始人
2024-09-03 00:32:28
0

在BigQuery中,可以使用标准SQL中的LAG()函数来获取最接近的前一个值,并进行左连接。以下是一个包含代码示例的解决方法:

WITH data AS (
  SELECT '2021-01-01' AS date, 10 AS value UNION ALL
  SELECT '2021-01-03' AS date, 20 AS value UNION ALL
  SELECT '2021-01-06' AS date, 30 AS value
), reference AS (
  SELECT '2021-01-02' AS date, 100 AS reference_value UNION ALL
  SELECT '2021-01-04' AS date, 200 AS reference_value UNION ALL
  SELECT '2021-01-05' AS date, 300 AS reference_value
)
SELECT 
  data.date,
  data.value,
  reference.date AS reference_date,
  reference.reference_value
FROM 
  data
LEFT JOIN 
  reference ON data.date = reference.date OR data.date = LAG(reference.date) OVER (ORDER BY reference.date)

在上面的示例中,我们有两个表:datareferencedata表包含日期和值,reference表包含日期和参考值。通过使用LAG()函数,我们将data表的日期与reference表的日期进行比较,找到最接近的前一个日期,并进行左连接。

运行此查询会返回以下结果:

+------------+-------+----------------+------------------+
| date       | value | reference_date | reference_value  |
+------------+-------+----------------+------------------+
| 2021-01-01 | 10    | null           | null             |
| 2021-01-03 | 20    | 2021-01-02     | 100              |
| 2021-01-06 | 30    | 2021-01-05     | 300              |
+------------+-------+----------------+------------------+

注意:在实际使用中,你需要替换datareference的表名以及选择你需要的列。

相关内容

热门资讯

程序员教你!超凡辅助app链接... 程序员教你!超凡辅助app链接(白金岛手游放炮罚有挂)切实有作弊器开挂辅助工具(有挂猫腻);白金岛手...
玩家必看教程!518互游辅助(... 【福星临门,好运相随】;玩家必看教程!518互游辅助(如何做方片十三张脚本)从前有作弊器开挂辅助黑科...
玩家必看教程!新海豚辅助工具(... 玩家必看教程!新海豚辅助工具(微友助手破解版)好像有作弊挂开挂辅助神器(有挂秘笈);1、让任何用户在...
分享一款!新众亿软件可以安装(... 分享一款!新众亿软件可以安装(福州十八扑外卦)一向有作弊挂开挂辅助下载(今日头条);分享一款!新众亿...
实测教程!新财神正版辅助挂(游... 实测教程!新财神正版辅助挂(游戏辅助器免费版)其实有作弊挂开挂辅助插件(有挂辅助);游戏辅助器免费版...
玩家必看!新九哥智能辅助软件(... 玩家必看!新九哥智能辅助软件(小程序能不能开挂)确实有作弊器开挂辅助神器(有挂技巧);新九哥智能辅助...
信息共享!火神工作室辅助大全(... 信息共享!火神工作室辅助大全(朋友圈辅助软件)果然有作弊挂开挂辅助神器(有挂工具);一、火神工作室辅...
玩家必看科普!樱花之盛免费挂(... 玩家必看科普!樱花之盛免费挂(边锋老友辅助)固有有作弊挂开挂辅助脚本(有挂秘籍);亲真的是有正版授权...
总算清楚!天天微友辅助神器(上... 总算清楚!天天微友辅助神器(上饶打炸辅助)最初有作弊器开挂辅助工具(确实有挂);天天微友辅助神器 a...
科技新动态!微友辅助神器下载(... 科技新动态!微友辅助神器下载(人海大厅脚本)最初有作弊挂开挂辅助神器(有挂头条);科技新动态!微友辅...