MySQL之如何删除重复数据只保留一条
2019獨角獸企業重金招聘Python工程師標準>>>
背景: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執行刪除操作就可以了。
轉載于:https://my.oschina.net/guquanxin/blog/3044375
總結
以上是生活随笔為你收集整理的MySQL之如何删除重复数据只保留一条的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 四十一、下载附件
- 下一篇: let const —— ES6基础总