首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在MySQL中选择随机最大值

在MySQL中选择随机最大值
EN

Stack Overflow用户
提问于 2011-07-08 06:38:53
回答 3查看 566关注 0票数 0

我有一张桌子:

代码语言:javascript
复制
id    name    bid
1     Test1   5.50
2     Test2   5.50
3     Test3   5.49

我想选择出价最高的行。如果最高出价在另一行上相等,那么它应该随机选择出价最高的行之一。

我试过了:

代码语言:javascript
复制
SELECT name,max(bid) FROM table ORDER BY rand()

输出:

代码语言:javascript
复制
id    name    bid
1     Test1   5.50

我的问题是id "2“从不显示,因为出于某种原因,我的查询只选择id "1”。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-07-08 06:49:46

同一查询中的SELECTing nameMAX(bid)没有任何意义:您要求的是聚合所有行的最高出价,外加一个未聚合的名称,因此根本不清楚您将选择哪一行的名称。MySQL通常会选择您想要的“正确”答案(拥有最大出价的行之一),但这不能得到保证,在所有其他数据库中都会失败,并且在ANSI SQL中是无效的。

要获得出价最高的行,请按bid排序,并仅选取第一个结果。如果您希望确保获得一个随机的出价最高的行,而不只是一个任意的行,请在order子句中添加一个随机因子:

代码语言:javascript
复制
SELECT name, bid
FROM table
ORDER BY bid DESC, RAND()
LIMIT 1
票数 2
EN

Stack Overflow用户

发布于 2011-07-08 06:46:55

代码语言:javascript
复制
SELECT name,bid
FROM table
WHERE bid=(SELECT max(bid) FROM table)
ORDER BY RAND()
LIMIT 1

应该能行得通。正在等待更优化的请求^^

票数 2
EN

Stack Overflow用户

发布于 2011-07-08 06:48:25

这是因为您使用的是聚合函数,它将所有内容折叠到一行中。您需要一个子选择:

代码语言:javascript
复制
SELECT *
FROM table
WHERE bid = (SELECT MAX(bid) FROM table)
ORDER BY rand()
LIMIT 1;

但也要注意why not to use ORDER BY RAND()。尽管您只有几个结果,但性能影响可能不会显著到需要更改的地步。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6617973

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档