提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:黄竹雯|2019-01-31 09:22:37.000|阅读 714 次
概述:本篇文章介绍了如何删除MySQL中具有不同ID的重复行。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
相关链接:
Navicat Premium是一个可连接多种数据库的管理工具,它可以让你以单一程序同时连接到MySQL、Oracle及PostgreSQL数据库,让管理不同类型的数据库更加的方便。
大多数重复记录分为两类:重复意义和非唯一键。在Navicat使用教程:如何在MySQL中定位和删除有重复意义的值中,如何识别和删除具有重复意义的值涉及到重复意义;在Navicat使用教程:如何用非唯一键识别重复项中涉及到如何识别非唯一密钥。这意味着同一表中的两个记录具有相同的键,但可能具有或不具有不同的值和含义。这篇文章将介绍如何删除具有重复数据但具有不同键的行。
在Navicat使用教程:如何用非唯一键识别重复项中显示的最后一个查询以易于直观扫描的格式列出了所有重复项:
Repetitions row_data ---------------------------------------------------------------- 2 22 (DAVIS, JENNIFER) | 22 (DAVIS, JENNIFER) 2 23 (LOLLOBRIGIDA, JOHNNY) | 23 (GABLE, CHRISTIAN) 2 41 (WAHLBERG, NICK) | 12 (WAHLBERG, NICK)
在识别了所有重复的键和值之后,我们可以决定如何最好地处理冗余数据。
JENNIFER DAVIS以相同的22键出现在两个记录中,使这些行完全重复。Nick Walberg的名称字段是重复的,但ID不是。还有一个与两个无关的演员相关联的复制键:“JOHNNY LOLLOBRIGIDA”和“CHRISTIAN GABLE”的复制键#23。对于22和23的重复键,第一个键是真正的重复键,而第二个键只需要为其中一个记录生成一个新键。
在Navicat使用教程:如何在MySQL中定位和删除有重复意义的值中,我们通过对值执行搜索和替换,从选择的结果集中删除了重复的值。在这里,我们将使用DELETE JOIN语句永久删除其中一个重复的行。
因为我们正在比较同一个表中的字段,所以必须将该表与其自身联接。我们可以通过比较WHERE子句中的ID来选择保留较低或较高的ID号。以下语句保留最高的ID:
DELETE a FROM wp.amalgamated_actors a INNER JOIN wp.amalgamated_actors a2 WHERE a.id < a2.id AND a.first_name = a2.first_name AND a.last_name = a2.last_name; 1 row(s) affected 0.093 sec
在本例中,受影响(已删除)行是标识为12的NICK WAHLBERG。快速选择确认结果:
id first_name last_name ------------------------------------- 10 PENELOPE GUINESS 12 NICK WAHLBERG 14 ED CHASE 22 JENNIFER DAVIS 23 JOHNNY LOLLOBRIGIDA 27 BETTE NICHOLSON 34 GRACE MOSTEL 39 JOE SWANK 23 CHRISTIAN GABLE 22 JENNIFER DAVIS
如果要保持最低的ID,只需将a.id
id first_name last_name ------------------------------------- 10 PENELOPE GUINESS 14 ED CHASE 22 JENNIFER DAVIS 23 JOHNNY LOLLOBRIGIDA 27 BETTE NICHOLSON 34 GRACE MOSTEL 41 NICK WAHLBERG 39 JOE SWANK 23 CHRISTIAN GABLE 22 JENNIFER DAVIS
在JENNIFER DAVIS的例子中,他出现两次,同一个ID为22,我们需要使用不同的方法,因为使用a.id=a2.id运行上面的语句将针对表中的每一行!原因是我们基本上是在将每一行与自身进行匹配!在下一篇文章中,我们将学习如何删除具有非唯一键的行,如这些键。
购买Navicat Premium正版授权,请点击“”哟!
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@capbkgr.cn
本文探讨 SQL Server 中 NULL 和空值之间的区别,并讨论如何有效地处理它们。
Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
Navicat Premium 是一套数据库管理工具,让你使用一个程序即可同時连接到 MySQL、MariaDB、SQL Server、SQLite、Oracle 和 PostgreSQL 数据库。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@capbkgr.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢