您好,登錄后才能下訂單哦!
這篇文章主要講解了“MySql如何查出符合條件的最新數據行”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“MySql如何查出符合條件的最新數據行”吧!
這是一張記錄人員來訪的記錄表。
數據表里的數據準確記錄了每個人來訪時帶的帽子顏色、時間、人員編碼(每個人唯一)。
拿出符合條件的最新的來訪記錄。
你會最怎么做?
先實現一點的, 取出 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相當于把整個表當作了一個內容塊去進行一個壓縮檢索。
我們加上了where 條件 user_code='A101',所以整個內容塊確實過濾掉了其他不是user_code='A101' 的數據。
也就是說這種松懈執行的情況下,mysql保證max 返回(相關列) 的最大值, 其他列字段它是不保證的。
正確的數據是 :
那是不是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' )
查詢結果:
但是看到上面使用子查詢的這種方式,
大家心里面肯定也已經在暗暗地罵娘, 拿個最新數據這么麻煩?
有沒有簡單一點的?
有。
比如說,我們已經確定了, id是自增的,id最大的數據(符合條件的數據) 就是最新的。
那么我們就可以使用倒序 DESC 來取最新數據:
DESC 也就是 倒序/降序 。
PS:
使用倒序查找:
SELECT *
FROM vist_record
WHERE user_code='A101'
ORDER BY id DESC
LIMIT 1;
查詢結果:
或者根據時間倒序:
SELECT *
FROM vist_record
WHERE user_code='A101'
ORDER BY create_time DESC
LIMIT 1;
查詢結果:
就這么簡單實現了嗎?
那么我們如果需求要的不是指定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如何查出符合條件的最新數據行這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。