msyql 去重

delete from userinfo where busi_id in
(select busi_id from
(select busi_id from userinfo group by busi_id having count(busi_id)>1) tmp1)
and id not in
(select id from
(select min(id) id from userinfo group by busi_id having count(busi_id)>1) tmp2);


無主鍵 添加主鍵再去重操做。


DELETE FROM user WHERE id NOT IN ( SELECT temp.min_id FROM ( SELECT MIN(id) min_id FROM user GROUP BY name,age )AS temp );

若是在設計表時沒有指定主鍵,
導入數據時可能出現重複導入,
致使一個表中出現多條徹底相同的多條記錄。
如下是解決這個問題的思路:sql

使用distinct語句篩選出不重複的記錄存入臨時表tmp;
create table tmp as (select distinct sno,sname,age,sex from s);
 
刪除原表中的數據記錄
delete from s;
 
將臨時表中的數據插入到原表。
insert into s select * from tmp;
 
刪除臨時表
drop table tmp; ui

 

 

 

 

有一張學生表,有姓名和性別(0:女,1:男),假如咱們想刪除姓名和性別都相同的數據,這裏介紹2中方法spa

首先看一下數據表設計

編號 姓名 性別
1  王璐 0
2  李萌 0
3  張帥  1 
4   李萌   0 
5  張帥  1 
6   劉濤   1 

NO.1code

保留id較小的數據blog

DELETE t1 FROM student t1, student t2
WHERE t1.name = t2.name AND t1.sex = t2.sex AND t1.id > t2.id

保留id較大的數據token

DELETE t1 FROM student t1, student t2
WHERE t1.name = t2.name AND t1.sex = t2.sex AND t1.id < t2.id

 

注意最後的t1.id > t2.id不要忘記,不然會刪除全部的數據,操做以前必定要先備份好數據io

 

NO.2table

INSERT INTO student_tmp(name, sex)
SELECT DISTINCT name, sex FROM student

 

總結function

兩種方法優缺點:

方法二所需時間更短,可是方法二當主鍵爲uuid時,須要處理一下,可將把主鍵設置爲int自增,而後執行下面的sql就能夠了。

UPDATE student_tmp SET id = uuid()
相關文章
相關標籤/搜索