从数据库表中获取列中最小值的相应行属性

时间:2016-12-12 22:54:01

标签: python sql

我有一个包含以下数据的MySQL表:

ID,PERSON_NAME,SCORE,DATE

我正在尝试编写一个查询,我可以获得最小的SCORE值和相应的PERSON_NAME值。我尝试过以下查询:

viewmodel

但是,名称值始终相同,似乎是表中的第一个条目。我想获得MIN(SCORE)的相应PERSON_NAME值。我该如何撰写该查询?

2 个答案:

答案 0 :(得分:1)

试试这个:

SELECT PERSON_NAME, SCORE
FROM HTMLSCORES
WHERE SCORE =
(SELECT MIN(SCORE)
 FROM HTMLSCORES)

首先查看子查询。我们可以使用MIN函数从您的表中找到MIN分数。然后,在主查询中,我们选择该行中得分与子查询得分匹配的一行或多行。

您的首次尝试无效,因为查询会独立查看人名和分数。以这种方式编写查询会将它们链接在一起。

答案 1 :(得分:1)

min_query = "SELECT PERSON_NAME, MIN(SCORE) AS 'Min_Score' FROM HTMLSCORES GROUP BY PERSON_NAME ORDER BY PERSON_NAME"

这将返回所有PERSON_NAME的列表及其最低分数。

如果您追踪特定用户并知道应该使用PERSON_NAME

pyPerson = 'Name Here'    
min_query = "SELECT PERSON_NAME, MIN(SCORE) AS 'Min_Score' FROM HTMLSCORES  WHERE PERSON_NAME = '" + str(pyPerson) + "' GROUP BY PERSON_NAME" 

请原谅我粗略的python,但它应该在SQL上工作。