mysql--记2次脏数据清理

2022/5/24 2:20:00

本文主要是介绍mysql--记2次脏数据清理,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

有时候程序执行的过程中,可能有逻辑漏洞,导致同样一条数据多次insert到表里,造成了垃圾数据,在清理的时候又不能一杆子都打死,需要将重复数据中,id最小的保留

DELETE FROM public_sentiment WHERE id IN (
    SELECT * FROM (
        SELECT id FROM public_sentiment WHERE (sentiment_id,vuln_name)         IN (
            SELECT sentiment_id,vuln_name FROM public_sentiment GROUP BY sentiment_id,vuln_name HAVING COUNT(1) > 1
        ) AND id NOT IN (
            SELECT MIN(id) FROM public_sentiment GROUP BY sentiment_id,vuln_name HAVING COUNT(1) > 1
        )
    ) AS repeat_copy

);

  

DELETE FROM 表名 WHERE id IN (
    SELECT * FROM (
        SELECT id FROM 表名 WHERE (字段名1)  IN (
            SELECT 字段名1 FROM 表名 GROUP BY 字段名1 HAVING COUNT(1) > 1
        ) AND id NOT IN (
            SELECT MIN(id) FROM 表名 GROUP BY 字段名1  HAVING COUNT(1) > 1
        )
    ) AS repeat_copy

);

 



这篇关于mysql--记2次脏数据清理的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程