当前位置: 首页 > 面试题库 >

SQL按日期合并3个表,其中缺少某些日期

公西鸿博
2023-03-14
问题内容

我有3个表要合并,每个表都有不同的关注列。我也有一个id变量,我想在id内进行单独的合并。我的想法是,我想按日期(在ID内)合并X,Y和Z,并且如果特定变量不存在该日期,则缺少值。

Table X:
ID     Date         X
1      2012-01-01   101
1      2012-01-02   102
1      2012-01-03   103
1      2012-01-04   104
1      2012-01-05   105
2      2012-01-01   150

Table Y:
ID     Date         Y
1      2012-01-01   301
1      2012-01-02   302
1      2012-01-03   303
1      2012-01-11   311
2      2012-01-01   350

Table Z:
ID     Date         Z
1      2012-01-01   401
1      2012-01-03   403
1      2012-01-04   404
1      2012-01-11   411
1      2012-01-21   421
2      2012-01-01   450

Desired Result Table:
ID     Date         X     Y     Z
1      2012-01-01   101   301   401
1      2012-01-02   102   302   .
1      2012-01-03   103   303   403
1      2012-01-04   104   .     404
1      2012-01-05   105   .     .
1      2012-01-11   .     311   411
1      2012-01-21   .     .     421
2      2012-01-01   150   350   450

任何想法如何编写此SQL语句?我尝试弄乱“完全连接”和叉积的where语句,但是我一直在获取某些ID-日期组合(有时甚至没有ID)的重复值。

任何帮助,将不胜感激。


问题答案:

加入可能是棘手的事情。我通常的方法是先形成一组键,然后使用这些键得到我想要的。

SELECT source.ID, source.Date, x.X, y.Y, z.Z
FROM
(
  SELECT ID, Date
  FROM TableX
  UNION
  SELECT ID, Date
  FROM TableY
  UNION
  SELECT ID, Date
  FROM TableZ
) as source
LEFT JOIN TableX x ON source.ID = x.ID AND source.Date = x.Date
LEFT JOIN TableY y ON source.ID = y.ID AND source.Date = y.Date
LEFT JOIN TableZ z ON source.ID = z.ID AND source.Date = z.Date
ORDER BY source.ID, source.Date


 类似资料:
  • 问题内容: 我想知道如何使用循环根据sql中各组的开始/结束日期来填充零值缺失日期,以便每个组中都有连续的时间序列。我有两个问题。 如何为每个组循环播放? 如何使用每个组的开始/结束日期来动态填写缺少的日期? 我的输入和预期输出如下所示。 输入: 我有一张表A喜欢 我还有一张表B,可用于与A左联接以填写缺少的日期。 如何使用A和B在sql中生成以下输出? 输出: 请给我您的代码和建议。提前非常感谢

  • 问题内容: 我有一张可以容纳一年中所有天/月的表 例如 我有一张表格,显示来自不同数据集的日期范围 例如 我如何比较这两个表以显示该特定月份的数据集中缺少哪些日期 对于上面示例中的数据集所在的示例,EG缺少日期范围01/09/2013-19/09/2013 谢谢你的帮助! 问题答案: 您可以使用CTE并通过以下方式编写查询:

  • 问题内容: 我有一个包含时间戳名为RDD 时间 长整型: 我正在尝试按值1,值2和时间分组为YYYY-MM-DD。我尝试按演员分组(时间为日期),但随后出现以下错误: 这是否意味着无法按日期分组?我什至尝试添加另一级别的强制转换以将其作为字符串: 哪个返回相同的错误。 我已经读到我可以在RDD上使用gregationByKey,但我不明白如何在几列中使用它并将其转换为YYYY-MM-DD字符串。我

  • 问题内容: 我有以下两个表,您也可以在此处的SQL提琴中找到它们: 我从这里使用VBA 合并两个表: 所有这些完美地工作。 但是,现在我希望日期显示为唯一。 结果应如下所示: 我需要在代码中进行哪些更改才能使其正常工作? 问题答案: 使用和:

  • 问题内容: 我在一个字段中有一个表格(其中包括日期)。 我需要获取所有列表的列表,这些列表比最早的日期更早,比最新的日期更早并且在表格中完全丢失。 因此,如果表包含: 我想要一个返回的查询: 问题答案: 这样的事情(假设您的表被命名,而date列被命名): 编辑: 该子句称为“公用表表达式”,等效于派生表(“内联视图”)。 类似于 第二个CTE使用Oracle实现中未记录的功能简单地“即时”创建日

  • 问题内容: 我通过网络研究和自己的SQL知识(不是最大的知识)拼凑了以下代码。 该表包含员工及其工作日的数据,我要做的是在每个工作人员两个指定日期之间缺少日期(非工作日)的行。 据我所知,我不知道如何检查该行是否丢失,如果存在,请插入带有日期和相应工作人员数据的新行。 桌子看起来像这样 该工作人员的两个日期之间的第一行数据将能够用于填充日期列以外的其他列。而且每个工作人员的第一行数据不一定都在同一