繁体   English   中英

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

[英]Get corresponding row properties for min value in column from database table

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

ID,PERSON_NAME,SCORE,DATE

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

min_query = "SELECT PERSON_NAME, MIN(SCORE) FROM HTMLSCORES"

cursor.execute(min_query)

result = cursor.fetchone()
name = result[0]
min_score = result[1]

但是,名称值始终相同,并且似乎是表中的第一项。 我想获取MIN(SCORE)的相应PERSON_NAME值。 我该如何编写该查询?

尝试这个:

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

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

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

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上正常工作。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM