参与日期代码时的SQL连接

时间:2013-07-18 21:32:09

标签: sql

我对某事感到好奇。我们说我有两张桌子,一张有销售和促销代码,另一张只有促销代码和属性。促销代码可以打开和关闭,但促销属性可以更改。这是表结构:

tblSales                    tblPromo
sale  promo_cd  date        promo_cd  attribute   active_dt  inactive_dt
  2     AAA    1/1/2013        AAA      "fun"      1/1/2013    1/1/3001
  3     AAA    6/2/2013        BBB      "boo"      1/1/2013    6/1/2013
  8     BBB     2/2/2013       BBB      "green"    6/2/2013    1/1/3001
  9     BBB     2/3/2013
  10    BBB     8/1/2013

请注意,这不是我的表/架构/设计。我不明白为什么他们不为每个属性变化做新的promo_cd,特别是当属性是我们想要测量的时候。无论如何,我试图制作一个看起来像这样的表:

sale  promo_cd   attribute
  2     AAA        fun
  3     AAA        fun
  8     BBB        boo
  9     BBB        boo
  10    BBB        green

到目前为止我唯一做的就是创建一个内部联接(导致重复记录),然后通过比较销售日期与促销活动/非活动日期进行过滤。有没有更好的方法来做到这一点?我真的很好奇,因为这是一个非常大的数据集,我喜欢保持它的效率。

3 个答案:

答案 0 :(得分:1)

这是我喜欢将过滤条件直接放入JOIN子句的情况之一。至少在我的大脑中,重复的记录永远不会进入结果集。这为实际的过滤条件留下了WHERE子句。

Select s.sale, s.promo_cd, p.attribute
From tblSales s
  Inner Join tblPromo p 
    on s.promo_cd=p.promo_cd 
    and s.date between p.active_dt and p.inactive_dt

答案 1 :(得分:1)

假设我理解正确,您可以使用:

SELECT s.sale, s.promo_cd, p.attribute
    FROM tblSales s
    JOIN tblPromo p ON p.promo_cd = s.promo_cd AND s.date BETWEENp.active_dt and p.inactive_dt

这假设tblPromo日期永远不会重叠(看起来很可能是他们选择的模式)

答案 2 :(得分:1)

只需将日期添加到JOIN条件:

SELECT a.sale, a.promo_cd, b.attribute
FROM tblSales a
JOIN tblPromo b
   ON a.promo_cd = b.promo_cd
   AND a.date BETWEEN b.active_dt AND b.inactive_dt

演示:SQL Fiddle