如何删除数据库中的重复记录(一)

php中文网
发布: 2016-06-07 14:59:40
原创
2132人浏览过

今天去西安一家公司去面试,其中有一道面试题是这样的:“如何删除在数据表中完全相同的记录,如果两条相同的记录主键不同,那么又应该如何删除” ,当时因为是很简单的题目就直接用sql语句完成,面试官看了之后说这个有问题。回来研究一下果然错了。现在把

   今天去西安一家公司去面试,其中有一道面试题是这样的:“如何删除在数据表中完全相同的记录,如果两条相同的记录主键不同,那么又应该如何删除” ,当时因为是很简单的题目就直接用sql语句完成,面试官看了之后说这个有问题。回来研究一下果然错了。现在把研究的步骤分享下来。

   研究条件: 

    window7 + no-install mysql 

 1. 如何删除除了主键不同其他属性均相同的记录

    主要思想:首先从数据表中找出没有重复的数据记录,然后把这些记录保存到临时表中,然后删除原表记录把临时表中的记录迁移过去。

   具体步骤: 

    一、 查看下表在student中有两条相同记录,有distinct查找不同的记录(如右图)。

       如何删除数据库中的重复记录(一)     如何删除数据库中的重复记录(一)   

双轨制会员管理系统 v9.1
双轨制会员管理系统 v9.1

双轨制会员管理系统是一个以asp+access进行开发的双轨制直销系统源码,要求很低,容易维护。 后台路径:/admin 后台用户名和密码均为:admin 9.1版更新内容: 1、增加了操作余额前自动备份数据库,如果操作成功,则自动删除备份的数据库;如果操作有页面错误导致不成功,则会自动恢复到备份的数据库。这样运行过程中,即使是程序错误,也不用担心数据丢失了。 2、增加会员登录首

双轨制会员管理系统 v9.1 843
查看详情 双轨制会员管理系统 v9.1

  二、 创建临时表,把上面右图的数据迁移到临时表student_temp中.

           sql语句: create temporary table if not exists student_temp as (select distinct(name), sex from student);

            如何删除数据库中的重复记录(一)

    三、 删除原表内容或者重新创建张新表,本例采用在原表基础上修改,然后把student_temp内容迁移到student,最后结果如下图所示:

           用到sql: insert into student(id, name,sex ) select null,name,sex from student_temp;

                      如何删除数据库中的重复记录(一)                                

      最后就可以看到student表中只有两条不同数据了。 

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号