我正在尝试选择每个user_id具有最高date_end值的行。 date_end可以为null,在这种情况下,我假设当前(或给定)日期为:
数据:
CREATE TABLE `prices_test` (
`id` int(10) unsigned NOT NULL DEFAULT '0',
`user_id` int(10) NOT NULL,
`date_end` date DEFAULT NULL,
`price` decimal(10,2) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
-- ----------------------------
-- Records of prices_test
-- ----------------------------
INSERT INTO `prices_test` VALUES ('2', '2', '2018-11-29', '30000.00');
INSERT INTO `prices_test` VALUES ('3', '6', '2018-07-29', '20000.00');
INSERT INTO `prices_test` VALUES ('4', '18', '2017-12-31', '3999.00');
INSERT INTO `prices_test` VALUES ('7', '18', '2018-03-01', '10000.00');
INSERT INTO `prices_test` VALUES ('10', '6', null, '44000.00');
INSERT INTO `prices_test` VALUES ('13', '62', '2018-08-26', '12000.00');
INSERT INTO `prices_test` VALUES ('16', '62', null, '36500.00');
INSERT INTO `prices_test` VALUES ('17', '68', '2014-06-15', '22000.00');
INSERT INTO `prices_test` VALUES ('18', '69', null, '36500.00');
INSERT INTO `prices_test` VALUES ('19', '60', null, '10000.00');
INSERT INTO `prices_test` VALUES ('20', '68', null, '30000.00');
以及我要使用的查询:
SELECT t.*
FROM prices_test t
INNER JOIN (
SELECT id, user_id, MAX(IFNULL(date_end, '2019-03-21')) AS date_end
FROM prices_test GROUP BY id
) AS max USING (id, date_end);
sql小提琴:http://sqlfiddle.com/#!9/9e61e0/4
问题是我的查询似乎忽略了MAX()。它选择id = 3的user_id,但我希望id = 10,因为IFNULL(date_end,'2019-03-21')给id = 10比id = 3的日期要长于'2018-07-29',对吗?其他所有ID也不符合预期。
我在做什么错了?
答案 0 :(得分:1)
使用相关子查询
select * from prices_test a
where id in (select max(id) from prices_test b where a.user_id=b.user_id)
OR
select * from prices_test a
where coalesce(date_end,'2019-03-21') in (select max(coalesce(date_end,'2019-03-21')) from prices_test b where a.user_id=b.user_id)
答案 1 :(得分:1)
您不应该使用id来分组。这样,您将获得每个id的最大值 (每行),而不是针对每个user_id ..也尝试对ID列使用聚合函数
SELECT t.*
FROM prices_test t
INNER JOIN (
SELECT max(id), user_id, MAX(IFNULL(date_end, '2019-03-21')) AS date_end
FROM prices_test
GROUP BY user_id
) AS max USING (id, date_end);