1. 程式人生 > >MySQL之如何刪除重複資料只保留一條

MySQL之如何刪除重複資料只保留一條

背景:task表中儲存有車的代辦工單的資料,因為歷史原因,該資料表中儲存有同一個車同一個status的多條資料,現在需要將歷史資料都刪掉,只保留同一個車同一個狀態下的最新一條記錄即可,那麼這個sql該怎麼寫呢?

實現這個需求,我們先要了解幾個MySQL的函式:

第一個函式是group by和group_concat。group_concat的作用是將group by產生的同一個分組中的值連線起來,返回一個字串結果。因為我們是想獲取非最新的資料id,然後根據id將資料進行刪除。我們可以結合group_concat和order by實現目的,當然order by不是放在where之後,而是放在group_concat的括號裡面(此處如果放在where的後面,是沒有排序效果的)。

第二個函式,如果有字串是123,456,789,如果我想獲取第一個逗號以後的內容,該怎麼辦,這時候我們要用到LOCATE和SUBSTRING函式,例如:SELECT SUBSTRING('123,456,789',LOCATE(',','123,456,789')+1),結果為456,789。補充一下,如果想獲取逗號之前的內容可以使用SUBSTRING_INDEX函式,示例為:SELECT SUBSTRING_INDEX('111,222,333,444,555,666',',',3),結果為獲取第三個逗號之前的內容,即111,222,333

下面開始整合sql:

SELECT 
    SUBSTRING(GROUP_CONCAT(id ORDER BY created_at DESC), LOCATE(',', GROUP_CONCAT(id ORDER BY created_at DESC)) + 1) AS ids, 
    GROUP_CONCAT(id ORDER BY created_at DESC) AS groupIds, GROUP_CONCAT(created_at) AS groupCreatedAt, 
    carId, COUNT(*) AS num
FROM 
    task
WHERE 
    type = 410 AND is_deleted = 0 AND status = 11
GROUP BY 
    carId
HAVING 
    num > 1
ORDER BY id ASC

結果集ids即排除了最新一條資料id,剩下我們將要刪除的ids,直接根據id執行刪除