我对某事感到好奇。我们说我有两张桌子,一张有销售和促销代码,另一张只有促销代码和属性。促销代码可以打开和关闭,但促销属性可以更改。这是表结构:
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
到目前为止我唯一做的就是创建一个内部联接(导致重复记录),然后通过比较销售日期与促销活动/非活动日期进行过滤。有没有更好的方法来做到这一点?我真的很好奇,因为这是一个非常大的数据集,我喜欢保持它的效率。
答案 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