日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL之如何删除重复数据只保留一条

發(fā)布時間:2024/4/17 数据库 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL之如何删除重复数据只保留一条 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

2019獨角獸企業(yè)重金招聘Python工程師標(biāo)準(zhǔn)>>>

背景:task表中保存有車的代辦工單的數(shù)據(jù),因為歷史原因,該數(shù)據(jù)表中保存有同一個車同一個status的多條數(shù)據(jù),現(xiàn)在需要將歷史數(shù)據(jù)都刪掉,只保留同一個車同一個狀態(tài)下的最新一條記錄即可,那么這個sql該怎么寫呢?

實現(xiàn)這個需求,我們先要了解幾個MySQL的函數(shù):

第一個函數(shù)是group by和group_concat。group_concat的作用是將group by產(chǎn)生的同一個分組中的值連接起來,返回一個字符串結(jié)果。因為我們是想獲取非最新的數(shù)據(jù)id,然后根據(jù)id將數(shù)據(jù)進行刪除。我們可以結(jié)合group_concat和order by實現(xiàn)目的,當(dāng)然order by不是放在where之后,而是放在group_concat的括號里面(此處如果放在where的后面,是沒有排序效果的)。

第二個函數(shù),如果有字符串是123,456,789,如果我想獲取第一個逗號以后的內(nèi)容,該怎么辦,這時候我們要用到LOCATE和SUBSTRING函數(shù),例如:SELECT SUBSTRING('123,456,789',LOCATE(',','123,456,789')+1),結(jié)果為456,789。補充一下,如果想獲取逗號之前的內(nèi)容可以使用SUBSTRING_INDEX函數(shù),示例為:SELECT SUBSTRING_INDEX('111,222,333,444,555,666',',',3),結(jié)果為獲取第三個逗號之前的內(nèi)容,即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

結(jié)果集ids即排除了最新一條數(shù)據(jù)id,剩下我們將要刪除的ids,直接根據(jù)id執(zhí)行刪除操作就可以了。

轉(zhuǎn)載于:https://my.oschina.net/guquanxin/blog/3044375

總結(jié)

以上是生活随笔為你收集整理的MySQL之如何删除重复数据只保留一条的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。