久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

MySql如何查出符合條件的最新數據行

162次閱讀
沒有評論

共計 1556 個字符,預計需要花費 4 分鐘才能閱讀完成。

這篇文章主要講解了“MySql 如何查出符合條件的最新數據行”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著丸趣 TV 小編的思路慢慢深入,一起來研究和學習“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

錯誤的篩選結果:

MySql 如何查出符合條件的最新數據行

正確編碼:

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 如何查出符合條件的最新數據行”的內容了,經過本文的學習后,相信大家對 MySql 如何查出符合條件的最新數據行這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是丸趣 TV,丸趣 TV 小編將為大家推送更多相關知識點的文章,歡迎關注!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-07-13發表,共計1556字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 清水县| 噶尔县| 雷山县| 灵宝市| 呼图壁县| 罗源县| 淳化县| 鹿泉市| 吉木萨尔县| 白河县| 德阳市| 株洲市| 宁波市| 乌海市| 三穗县| 济南市| 灵璧县| 浦县| 洞口县| 长治市| 马龙县| 永宁县| 仪陇县| 苏尼特右旗| 奉新县| 浦城县| 龙陵县| 奉节县| 柏乡县| 泗洪县| 盐城市| 海门市| 宜州市| 儋州市| 周宁县| 天镇县| 微博| 昭通市| 鄂州市| 饶河县| 吉安市|