我正在使用SQLFire。我正在做一个作业,当我开始作业时,我发现我无法返回一个特定的值。请参阅此SQL,它包含我在赋值中使用的表中的确切数据,以及我尝试过的SQL语句。小提琴:http://sqlfiddle.com/#!2/e761ac/1
我想被输出的是:
Rate | RentalCode
-----------------
350 | WL当我在SQL中输入代码时,我会得到这个错误。

我被告知不要使用定单条款,我也没有学到“限制”。
谢谢
发布于 2013-08-20 05:40:51
您需要GROUP BY子句,因为在SELECT子句中有非聚合列。
SELECT MIN(Rate), Rentalcode
FROM RentalRates
GROUP BY Rentalcode更新
由于您希望获得最低的速率,我认为这是比使用ORDER BY - LIMIT更好的方法,因为它支持具有最低速率的多个记录。
SELECT *
FROM RentalRates
WHERE rate = (SELECT MIN(rate) FROM rentalrates)发布于 2013-08-20 05:46:12
不清楚您想从这个查询中得到什么。我想以下几点是可行的:
SELECT Rate, Rentalcode
FROM RentalRates
order by Rate
LIMIT 1SQLFiddle演示
发布于 2013-08-20 05:48:42
正如您所看到的,即使在SQLfiddle中,您的结果也是非常奇怪的--您从一个记录中获得RentalCode,从另一个记录中获得速度。
从表中选择聚合而不分组是MySQL语法,而不是ANSI。如果您想以最低速率获取记录,下面是一个查询:
select * from RentalRates order by Rate limit 1sql小提琴演示
https://stackoverflow.com/questions/18327673
复制相似问题