我有一个简单的表格,并且我想将它们按id_room
分组,并且只有在条件为真时才选择值。问题是,即使有一行右列日期列year_month
,该条件始终为假。MySQL - 组中的条件选择
下面是模式:
CREATE TABLE tbl_account_room (
`id` int,
`year_month` date,
`value` int,
`id_room` int
);
INSERT INTO tbl_account_room
(`id`, `year_month`, `value`, `id_room`)
VALUES
(1, '2016-08-01', 1, 300),
(2, '2016-09-01', 2, 300),
(3, '2016-10-01', 3, 300);
这里查询:
SELECT
(case when '2016-10-01' = ar.year_month then ar.value else 0 end) as total
FROM tbl_account_room AS ar
WHERE ar.year_month >= "2016-08-01"
AND ar.year_month <= "2016-11-01"
and ar.id_room = '300'
GROUP BY ar.id_room
LIMIT 10
这里是SQL Fiddle
在total
列我越来越0,我想获得价值3,因为year_month
是2016-10-01
。为什么会发生?