0

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

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

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

4

3 回答 3

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
于 2013-07-18T21:44:14.513 回答
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 日期永远不会重叠(考虑到他们选择的架构,这似乎很可能)

于 2013-07-18T21:45:03.913 回答
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 小提琴

于 2013-07-18T21:49:07.957 回答