Lat*_*son 15 mysql sql sum case
我正在尝试创建一个使用ASP.NET连接到MySQL数据库的GridView.数据如下所示.
BusinessUnit OrderDate Canceled
UnitA 1/15/2013 N
UnitA 10/1/2013 N
UnitB 10/15/2013 N
UnitB 10/22/2013 N
UnitB 10/22/2013 N
Run Code Online (Sandbox Code Playgroud)
根据上面的记录,我希望结果如下所示
BusinessUnit TodaysOrders ThisMonthsOrders ThisYearsOrders
UnitA 0 1 2
UnitB 2 3 3
Run Code Online (Sandbox Code Playgroud)
我目前的代码如下.它给了我错误(关于DatabaseName.sum的东西不存在.检查函数名称解析和解析'部分......)
Select
SUM (CASE WHEN (OrderDate)=DATE(NOW()) THEN 1 ELSE 0 END) AS TodaysOrders,
SUM (CASE WHEN YEAR(OrderDate) = YEAR(CURDATE()) AND MONTH(OrderDate) = MONTH(CURDATE()) THEN 1 ELSE 0 END) AS ThisMonthsOrders,
SUM (CASE WHEN YEAR(main_order_managers.creation_date) = YEAR(CURDATE()) THEN 1 ELSE 0 END) AS ThisYearsOrders
Run Code Online (Sandbox Code Playgroud)
代码继续
FROM OrderTable WHERE OrderTable.Canceled. <> 'Y';
Run Code Online (Sandbox Code Playgroud)
Sum Case在这里最好用吗?
pet*_*erm 23
该错误是由函数名称和括号之间的空格引起的
SUM (CASE WHEN ...
^^
Run Code Online (Sandbox Code Playgroud)
阅读更多功能名称解析和分辨率
尝试
SELECT BusinessUnit,
SUM(CASE WHEN OrderDate = CURDATE() THEN 1 ELSE 0 END) TodaysOrders,
SUM(CASE WHEN DATE_FORMAT(OrderDate, '%Y%m') = DATE_FORMAT(CURDATE(), '%Y%m') THEN 1 ELSE 0 END) ThisMonthsOrders,
SUM(CASE WHEN YEAR(OrderDate) = YEAR(CURDATE()) THEN 1 ELSE 0 END) ThisYearsOrders
FROM OrderTable
WHERE Canceled <> 'Y'
GROUP BY BusinessUnit
Run Code Online (Sandbox Code Playgroud)
这是SQLFiddle演示