簡體   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