91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySql怎么查詢符合條件的最新數據行

發布時間:2022-09-20 15:34:44 來源:億速云 閱讀:144 作者:iii 欄目:開發技術

這篇“MySql怎么查詢符合條件的最新數據行”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“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 也就是 倒序/降序 。

     使用倒序查找:

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

    查詢結果: 

    MySql怎么查詢符合條件的最新數據行

     或者根據時間倒序:

    SELECT *
    FROM vist_record
    WHERE user_code='A101'
    ORDER BY create_time DESC
    LIMIT 1;

    查詢結果: 

    MySql怎么查詢符合條件的最新數據行

    就這么簡單實現了嗎? 

    那么我們如果需求要的不是指定A101 要的是涉及到的每一個人的最新數據呢?

    也就是存在多組的概念。 

    每一類的符合條件的最新數據

    橙色框就是 A101 、B202 、 C303 分別的最新記錄 , 我們要取出來。

    MySql怎么查詢符合條件的最新數據行

    錯誤示例:

    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怎么查詢符合條件的最新數據行”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    抚宁县| 迁安市| 张家口市| 河间市| 武安市| 民和| 巴林右旗| 黄陵县| 阜阳市| 汉阴县| 万源市| 陵川县| 吴川市| 麻阳| 清水河县| 广宁县| 惠水县| 桓仁| 皋兰县| 淮阳县| 济南市| 长沙市| 沂源县| 哈尔滨市| 孟津县| 东山县| 株洲县| 白山市| 安国市| 海原县| 临颍县| 二连浩特市| 济阳县| 静乐县| 兴业县| 高淳县| 双桥区| 苏尼特左旗| 方正县| 隆安县| 车险|