1

这是一个非常奇怪的家伙,至少对我来说是这样。

我有一个查询,它检索过去几个月中前几个实体及其相关记录计数的一些统计信息。

一切正常,但它没有显示六月的结果。查询运行良好,只是不会给出 Junes 结果。

如果我执行以下任何操作,那么事情就会重新开始:

  1. 将 IN 子句更改为连接,而不是使用子查询返回与 IN 子句使用的完全相同的列表
  2. 将周数添加到组中,因为我已经检查过该组应该是不必要的,并且正确解析了记录的 MonthNumber。

但我真的想找出为什么会发生这种情况,而不仅仅是修补查询。在我看来,我的查询应该有效。

SELECT
YEAR(FROM_UNIXTIME(mt.`date_created`)) AS 'Year',
MONTH(FROM_UNIXTIME(mt.`date_created`)) AS 'MonthNumber',
MONTHNAME(FROM_UNIXTIME(mt.`date_created`)) AS 'MonthName',
WEEKOFYEAR(FROM_UNIXTIME(mt.`date_created`) ) AS 'Week',
`at`.`group_name`,
COUNT(`mt`.`mt_id_pk`) AS 'record_count' 
FROM
`my_table` AS `mt` 
INNER JOIN `another_table` AS `at` ON `mt`.`at_id_fk` = `at`.`at_id_pk` 
WHERE `at`.`group_name` IN ('something1','something2','something3')
GROUP BY `at`.`group_name`, `MonthNumber`
HAVING  `Year` = YEAR(NOW())
ORDER BY `MonthNumber` DESC
4

1 回答 1

1

YEAR() 不是一个聚合函数,不应该用于 HAVING 子句,它应该是这样的:

SELECT
YEAR(FROM_UNIXTIME(mt.`date_created`)) AS 'Year',
MONTH(FROM_UNIXTIME(mt.`date_created`)) AS 'MonthNumber',
MONTHNAME(FROM_UNIXTIME(mt.`date_created`)) AS 'MonthName',
WEEKOFYEAR(FROM_UNIXTIME(mt.`date_created`) ) AS 'Week',
`at`.`group_name`,
COUNT(`mt`.`mt_id_pk`) AS 'record_count' 
FROM
`my_table` AS `mt` 
INNER JOIN `another_table` AS `at` ON `mt`.`at_id_fk` = `at`.`at_id_pk` 
WHERE `at`.`group_name` IN ('something1','something2','something3')
AND YEAR(FROM_UNIXTIME(mt.`date_created`)) = YEAR(NOW())
GROUP BY `at`.`group_name`, `MonthNumber`
ORDER BY `MonthNumber` DESC
于 2013-06-07T11:39:53.187 回答