百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> mysql表中记录重复处理方案
分享文章到:

mysql表中记录重复处理方案

发布时间:01/15 来源: 浏览: 关键词:
记录重复的这些问题小编介绍过非常的多了,如果不信可以可以百度找找,下面一起来看小编整理的一篇mysql表中记录重复处理方案


今天写了一个airport表,主要有这么几个字段

//主键id,机场英文名称,机场中文名称,机场三字码,机场所在城市名子
id, name, c_name, code,city_name
由于机场三字码是不重复的,所以一开始我为airport表添加唯一索引


ALTER  TABLE  `airport`  ADD  UNIQUE (`code` );

但在写的过程中发现我爬虫爬到的信息有重复的情况,所以先暂时去掉唯一索引。


show index from airport;//查看索引情况
DROP INDEX code ON airport
上下爬虫程序代码

 

<?php
require('phpQuery.php');
phpQuery::newDocumentFile("http://******************因为某些原因***********");
$res = pq('tbody')->find('tr')->text();

根据自己的业务逻辑插入到表中

很快完成了工作,完成之后,还是要理解三字码重复的问题。

我的做法是采用了把所有重复的最小的三字码记录进行删除处理,最早写的代码如下:

DELETE FROM airport WHERE
id IN (SELECT id FROM airport GROUP BY code HAVING COUNT(code) > 1)
AND id NOT IN ( SELECT max(id) FROM airport GROUP BY code HAVING COUNT(code ) >1);

但运行这条sql的时候出错,原因是在选择的时候,不能同步进行删除或更新操作。这时候引用一个临时表吧


create TEMPORARY table tmp  select id from airport WHERE
id IN (SELECT id FROM airport GROUP BY code HAVING COUNT(code) > 1)
AND id NOT IN (SELECT max(id) FROM airport GROUP BY code HAVING COUNT(code ) >1);
 
delete from airport where id in (select id from tmp)
ok,操作完成,再看看有没有重复的情况:


SELECT id FROM airport GROUP BY code HAVING COUNT(code) > 1

如果有再进行删除。表的三字码已经不重复了,再为三字码添加唯一索引了。。。

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有12人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板