這是記錄人員來訪的記錄表。
資料表裡的資料準確地記錄了每個人來訪時帶的帽子顏色、時間、人員編碼(每個人唯一)。
先實現一點的, 取出 A101 這個人員編碼的 最新來訪記錄 。
首先先展示錯誤的sql範例: 想當然地使用max() 函數。#查詢結果(錯誤的結果) :SELECT MAX(id) AS id ,user_code,cap_color,create_time FROM vist_record WHERE user_code='A101' ;
為什麼是錯的,可以稍微講一下,既然評論區有人感興趣了(歡迎兄弟們說出自己的看法)。 簡單敘述, max是聚合函數, 我們的錯誤範例沒配合group by 去使用, 這時候其實也就mysql這個傢伙能讓我們執行了,很多資料庫都直接報錯的。 那麼執行是執行的,其實這時候mysql相當於把整個表格當作了一個內容區塊去進行一個壓縮檢索。正確的資料是 : 那是不是max(id) 用不了了? 正確用法(將符合條件的最大id值作為條件):也就是說這種鬆懈執行的情況下,mysql保證max 回傳(相關列) 的最大值, 其他列字段它是不保證的。
我們加上了where 條件 user_code='A101',所以整個內容區塊確實過濾掉了其他不是user_code='A101' 的資料。
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' )
查詢結果:
PS:
查詢結果:LIMIT 1;
SELECT *
FROM vist_record
WHERE user_code='A101'
ORDER BY id DESC
##或根據時間倒序:
WHERE user_code='A101'#SELECT *
FROM vist_record
ORDER BY create_time DESC
LIMIT 1;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如何找出符合條件的最新資料行的詳細內容。更多資訊請關注PHP中文網其他相關文章!