0

在下面的查询中,我正在连接一个表日历和第二个表,我需要在其中为查询指定一些参数。

表的连接是在字段 calendar.datefield 和 store_product.created 上执行的

问题是我正在按 id_store = 3 过滤,而 07/20/2012 store_product 表记录中的另一行有 id_store = 4,因此查询不会带来结果。有没有办法将此结果显示为NULL,迫使mysql忽略这种情况?

结果:(包含日期 2012-07-20 的行没有显示,因为它有其他 id_store)

DATE            price
2012-07-17      NULL
2012-07-18      700.00
2012-07-19      NULL
2012-07-21      NULL
2012-07-22      NULL
2012-07-23      NULL

我想显示

     DATE               price
     2012-07-17         NULL
     2012-07-18         700.00
     2012-07-19         NULL
->>> 2012-07-20         NULL
     2012-07-21         NULL
     2012-07-22         NULL
     2012-07-23         NULL

查询:

set @id_store = 3;
set @id_product = 11;

SELECT 
calendar.datefield as DATE,
t1.price
FROM
store_product t1
    RIGHT JOIN
calendar ON (DATE(t1.created) = calendar.datefield)
WHERE
(calendar.datefield BETWEEN ('2012-07-17') and ('2012-07-23'))
    AND (t1.id_store = @id_store OR t1.id_store is NULL)
    AND (t1.id_product = @id_product OR t1.id_product is NULL)
    AND (t1.created = (select 
        max(f2.created)
    from
        store_product f2
    where
        f2.id_store = t1.id_store
            and f2.id_product = t1.id_product
            and DATE(t1.created) = DATE(f2.created))
    OR t1.created is NULL)
GROUP BY DATE , t1.id_store , t1.id_product
4

1 回答 1

0

该记录无法显示(显然),因为您仅过滤了 ID 为 3 的商店。 RIGHT JOIN 完成了它应该做的事情,然后您将使用过滤器进一步减少结果。我认为您必须在主代码中处理此问题才能为您添加“缺失”记录。我不认为 SQL 可以做你想做的事。

于 2012-07-30T12:31:12.720 回答