所有周(52)我该怎么让SQL显示本年度
我有此查询的所有周(52)在当前年:
SELECT
COALESCE(IF(DATE_FORMAT(q.date_add, '%Y-%u') IS NULL,
(DATE_FORMAT(q.date_add, '%Y-%u')),
DATE_FORMAT(q.date_add, '%Y WEEK %u'))) AS CurrentDate,
COALESCE(IF(SUM(q.totalExcl) IS NULL,
0,
SUM(q.totalExcl))) AS total
FROM
expoled.ps_oxoquotation_quotationstate_history h
RIGHT JOIN
expoled.ps_oxoquotation_quotation q ON h.idQuotation = q.idQuotation
LEFT JOIN
expoled.ps_employee e ON h.idEmployee = e.id_employee
INNER JOIN
expoled.ps_sv_employee_meta m ON h.idEmployee = m.id_employee
WHERE
h.idEmployee = 39
AND YEAR(q.date_add) = YEAR(UTC_TIMESTAMP())
AND h.idQuotationState = 3
GROUP BY IFNULL(CurrentDate, '')
我想我需要做的这里有些东西:
SELECT
IFNULL(DATE_FORMAT(q.date_add, '%Y WEEK %u'), 0) AS CurrentDate,
IFNULL(SUM(q.totalExcl),0) AS total
FROM
我已经tryed把IFNULL但给了我同样的结果
这就是我得到现在:
从5显示当前周至16周 还有什么在1周,直到第4周,因为在没有数据和那里需要显示只是一个简单的零(0)
所以,我要的是它需要显示标准从1周,直到52周,如果没有数据只是0
查询工作,现在没有任何错误。
星期总是一个有趣的。你在说什么几个星期?既然你说52,我认为你的意思是ISO周? – Jens
是ISO周满52周 – Deniz
IFNULL(DATE_FORMAT(q.date_add,'%Y WEEK%u')),0)使用此 – Jenish