在特定日期之前查询没有值

Query without value before certain date

我正在接受数据库管理方面的培训,这是我第一次 post,所以如果我在 posting 中没有遵循标准程序,我深表歉意。我已经搜索过,但找不到答案。

在 PostgreSQL 中,我正在尝试查找 2014 年的所有新客户订单。但有些客户可能是在 2013 年或 2012 年添加的,但直到 2014 年才下订单。所以我正在尝试查询客户在 2014 年 1 月 1 日之前没有下订单,或者换句话说,他们的第一个订单是在 2013 年 12 月 31 日之后。

我知道这只显示 2014 年添加的新客户,我只需要以某种方式获取之前添加的客户。

SELECT DISTINCT cust_name, COUNT (cust_name)
FROM cohead
JOIN custinfo
ON cust_id=cohead_cust_id
WHERE cust_dateadded >='1/1/2014' AND cust_dateadded <='12/31/2014'
AND cohead_orderdate >='1/1/2014' AND cohead_orderdate <='12/31/2014'
GROUP BY cust_name
ORDER BY cust_name

在您发布的查询中,添加 DISTINCT 毫无意义,因为您已经有 GROUP BY cust_name.

但我建议采用一种可能更快的完全不同的方法。
这将检索在 2014 年首次下订单的所有客户 - 无论他们何时添加到 custinfo table:

SELECT *
FROM   custinfo cu
WHERE  EXISTS (  -- with order in 2014
   SELECT 1 FROM cohead
   WHERE  cohead_cust_id = cu.cust_id  -- guessing
   AND    cohead_orderdate BETWEEN '2014-01-01' AND '2014-12-31'
   )
AND    NOT EXISTS (  -- but no order before 2014
   SELECT 1 FROM cohead
   WHERE  cohead_cust_id = cu.cust_id
   AND    cohead_orderdate < '2014-01-01'  -- assuming a date column
   );

对于大 tables 一定要有索引来支持这个查询。