首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > Mysql >

Mysql剔除多余的重复记录

2013-11-05 
Mysql删除多余的重复记录有时候,数据库里会有多条重复记录。这个时候需要去重,也就是,多条重复记录只保留一

Mysql删除多余的重复记录

有时候,数据库里会有多条重复记录。这个时候需要去重,也就是,多条重复记录只保留一条。。。

尤其在数据仓库中,因为一些人为的原因,甚至疏忽,尤为常见。

如何去重呢?

步骤如下:

1.

查询出重复的记录

?

CREATE TABLE push_log_full_2013_10_30_tmpSELECT * FROM `push_log_full`WHERE time BETWEEN FROM_DAYS(TO_DAYS(NOW()) - 1) AND FROM_DAYS(TO_DAYS(NOW()))AND (imsi, andriodid, time) IN (SELECT imsi, andriodid, time FROM `push_log_full`WHERE time BETWEEN FROM_DAYS(TO_DAYS(NOW()) - 1) AND FROM_DAYS(TO_DAYS(NOW()))GROUP BY imsi, andriodid, timeHAVING COUNT(*) > 1)

?将重复的记录查出来放到一张临时表里面去。

?

2

删除push_log_full表中的重复数据。

3

将临时表的数据重新导入到push_log_full中。

?

?

通过以上三个步骤就实现了重复记录的去重。

热点排行