首頁 >資料庫 >mysql教程 >MySql如何找出符合條件的最新資料行

MySql如何找出符合條件的最新資料行

PHPz
PHPz轉載
2023-05-27 11:31:121636瀏覽

MySql如何找出符合條件的最新資料行

結合範例:

這是記錄人員來訪的記錄表。
資料表裡的資料準確地記錄了每個人來訪時帶的帽子顏色、時間、人員編碼(每個人唯一)。
MySql如何找出符合條件的最新資料行

資料範例:

MySql如何找出符合條件的最新資料行

#拿出符合條件的最新的來訪記錄。

你會最怎麼做?

先實現一點的, 取出 A101 這個人員編碼的 最新來訪記錄 。

首先先展示錯誤的sql範例: 想當然地使用max() 函數。


SELECT MAX(id) AS id ,user_code,cap_color,create_time FROM vist_record WHERE user_code='A101' ;

#查詢結果(錯誤的結果) :

MySql如何找出符合條件的最新資料行

顯然咋一看出來的資料有模有樣,但其實是錯的。

為什麼是錯的,可以稍微講一下,既然評論區有人感興趣了(歡迎兄弟們說出自己的看法)。

簡單敘述, max是聚合函數, 我們的錯誤範例沒配合group by 去使用, 這時候其實也就mysql這個傢伙能讓我們執行了,很多資料庫都直接報錯的。

那麼執行是執行的,其實這時候mysql相當於把整個表格當作了一個內容區塊去進行一個壓縮檢索。


我們加上了where 條件  user_code='A101',所以整個內容區塊確實過濾掉了其他不是user_code='A101' 的資料。

也就是說這種鬆懈執行的情況下,mysql保證max 回傳(相關列) 的最大值, 其他列字段它是不保證的。

正確的資料是 :

MySql如何找出符合條件的最新資料行

那是不是max(id) 用不了了?

正確用法(將符合條件的最大id值作為條件):


SELECT
 id,user_code,cap_color,create_time
FROM vist_record
WHERE id IN (SELECT MAX(id) AS id FROM vist_record WHERE user_code='A101' )


查詢結果:MySql如何找出符合條件的最新資料行

#但是看到上面使用子查詢的這種方式,

大家心裡一定也已經在暗暗地罵娘, 拿個最新資料這麼麻煩?

有沒有簡單一點的?

有。

比如說,我們已經確定了, id是自增的,id最大的資料(符合條件的資料) 就是最新的。

那麼我們就可以使用倒序 DESC 來取最新資料:

DESC 也就是 倒序/降序 。


PS:MySql如何找出符合條件的最新資料行

使用倒序尋找:


SELECT *
FROM vist_record
WHERE user_code='A101'
ORDER BY id DESC

LIMIT 1;

查詢結果:

MySql如何找出符合條件的最新資料行

##或根據時間倒序:





MySql如何找出符合條件的最新資料行

MySql如何找出符合條件的最新資料行


#SELECT *

FROM vist_record
WHERE user_code='A101'

ORDER BY create_time DESC

LIMIT 1;

MySql如何找出符合條件的最新資料行


############################################################################################################################################################################################################################### #########就這麼簡單實作了嗎? ######那麼我們如果需求要的不是指定A101 要的是涉及到的每一個人的最新資料呢? ######也就是存在多組的概念。 ######每一類的符合條件的最新資料######橘色框就是 A101 、B202 、 C303 分別的最新記錄 , 我們要取出。 ###############錯誤範例:############SELECT MAX(id) AS id ,user_code,cap_color,create_time FROM vist_record   GROUP BY user_code## #######錯誤的篩選結果:###############正確編碼:######

SELECT  id ,user_code,cap_color,create_time FROM vist_record  WHERE id in
(
SELECT MAX(id) AS id  FROM vist_record  GROUP BY user_code


MySql如何找出符合條件的最新資料行#

以上是MySql如何找出符合條件的最新資料行的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除