我有一张桌子:
id name bid
1 Test1 5.50
2 Test2 5.50
3 Test3 5.49我想选择出价最高的行。如果最高出价在另一行上相等,那么它应该随机选择出价最高的行之一。
我试过了:
SELECT name,max(bid) FROM table ORDER BY rand()输出:
id name bid
1 Test1 5.50我的问题是id "2“从不显示,因为出于某种原因,我的查询只选择id "1”。
发布于 2011-07-08 06:49:46
同一查询中的SELECTing name和MAX(bid)没有任何意义:您要求的是聚合所有行的最高出价,外加一个未聚合的名称,因此根本不清楚您将选择哪一行的名称。MySQL通常会选择您想要的“正确”答案(拥有最大出价的行之一),但这不能得到保证,在所有其他数据库中都会失败,并且在ANSI SQL中是无效的。
要获得出价最高的行,请按bid排序,并仅选取第一个结果。如果您希望确保获得一个随机的出价最高的行,而不只是一个任意的行,请在order子句中添加一个随机因子:
SELECT name, bid
FROM table
ORDER BY bid DESC, RAND()
LIMIT 1发布于 2011-07-08 06:46:55
SELECT name,bid
FROM table
WHERE bid=(SELECT max(bid) FROM table)
ORDER BY RAND()
LIMIT 1应该能行得通。正在等待更优化的请求^^
发布于 2011-07-08 06:48:25
这是因为您使用的是聚合函数,它将所有内容折叠到一行中。您需要一个子选择:
SELECT *
FROM table
WHERE bid = (SELECT MAX(bid) FROM table)
ORDER BY rand()
LIMIT 1;但也要注意why not to use ORDER BY RAND()。尽管您只有几个结果,但性能影响可能不会显著到需要更改的地步。
https://stackoverflow.com/questions/6617973
复制相似问题