Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/86.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
SQL:如何选择具有最大值和其他条件的行?_Sql_Sqlite - Fatal编程技术网

SQL:如何选择具有最大值和其他条件的行?

SQL:如何选择具有最大值和其他条件的行?,sql,sqlite,Sql,Sqlite,我想选择得分最高的行,但因为可以有很多行具有最大值,所以我希望另一列具有最高值的行。请考虑此列中的值不同。如何为此编写SQLite查询。这是我至今的想法: SELECT NAME, MAX(SCORE) FROM PLAYERS ORDER BY SECOND_COLUMN; 但它似乎不起作用。我该怎么做?请帮忙。 谢谢。如果我理解正确,您可以使用按顺序和限制执行您想要的操作: select p.* from players p order by score desc, second_colu

我想选择得分最高的行,但因为可以有很多行具有最大值,所以我希望另一列具有最高值的行。请考虑此列中的值不同。如何为此编写SQLite查询。这是我至今的想法:

SELECT NAME, MAX(SCORE) FROM PLAYERS ORDER BY SECOND_COLUMN;
但它似乎不起作用。我该怎么做?请帮忙。
谢谢。

如果我理解正确,您可以使用
按顺序
限制
执行您想要的操作:

select p.*
from players p
order by score desc, second_column
limit 1;

您的查询不起作用,因为
MAX(SCORE)
使其成为聚合查询。但是,没有
分组依据
,因此
名称
是一个语法错误。此外,由于聚合,未定义排序依据中的第二列。

您可以执行以下操作:

SELECT NAME, MAX(SCORE) FROM PLAYERS GROUP BY NAME ORDER BY MAX(SCORE);
SELECT NAME, SCORE 
FROM PLAYERS 
WHERE SCORE>=(SELECT MAX(SCORE) FROM PLAYERS)
ORDER BY SECOND_COLUMN DESC
LIMIT 1

这将得到所有得分相同的名称,然后按第二列排序,只返回最大值

我认为它也应该是
second\u column desc