加入收藏 | 设为首页 | 会员中心 | 我要投稿 武汉站长网 (https://www.027zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

一张表中存在两条一模一样的记录,如何删除其中一条?

发布时间:2023-02-02 10:04:16 所属栏目:MySql教程 来源:互联网
导读: 朋友们,我们在使用数据库的过程中,偶尔会犯一些低级错误。比如我们创建的某一张表,插入了两条一模一样的数据,想要删除其中一条怎么办?

这是笔者在头条问答中看到的一个问题,并做了回

朋友们,我们在使用数据库的过程中,偶尔会犯一些低级错误。比如我们创建的某一张表,插入了两条一模一样的数据,想要删除其中一条怎么办?

mysql插入数据_ajax技术如何同时向两个列数相同的表插入数据_数据库插入操作

这是笔者在头条问答中看到的一个问题,并做了回答。感觉这个问题挺有意思,看似简单的问题,我自己也曾经犯过这样的错误,我下面就以SQLServer为例,提一种处理方法供大家参考。

一张表出现多条一模一样的数据?

很多朋友可能会觉得奇怪,一张表里面怎么可能出现多条一模一样的数据呢?是的,正常情况这种情况是不应该发生的,因为我们创建的表基本都会有主键,想要一模一样是基本不可能的。

数据库插入操作_ajax技术如何同时向两个列数相同的表插入数据_mysql插入数据

但每个人对数据库的掌握程度和应用场景不同,有时候可能创建了一张表(如上图),阴差阳错的没有设置主键数据库插入操作,再阴差阳错的插入了两条或多条一模一样的数据,悲剧就这样产生了。

重复数据是无法直接删除的!

插进去容易,想要干掉却就难喽!如果您在MSSMS中想要删除这条记录,首先要打开表内容行列表,在某一行上单击鼠标右键执行删除菜单,如下图所示:

ajax技术如何同时向两个列数相同的表插入数据_数据库插入操作_mysql插入数据

您满心欢喜的以为就这样搞定了,开心早了!您可能想不到的是,MSSMS提示您:完全一致的数据无法删除!如下图所示:

ajax技术如何同时向两个列数相同的表插入数据_数据库插入操作_mysql插入数据

想写个SQL删除脚本来删除吗?

delete test where ...

可您where后面的条件怎么写,不写条件,两条就被一起干掉了哦,写条件,两条一模一样,您怎么写?

问题到这儿,感觉有点无解了!其实不用担心,方法还是有的。

为表结构增加一个自增字段

方法当然有很多,我推荐一个我自己用过的方法,那就是为表结构增加一个自增的int字段,通过这个字段将数据变成非完全一致,如下图所示:

mysql插入数据_数据库插入操作_ajax技术如何同时向两个列数相同的表插入数据

我们增加了一个FID字段,设置为自增字段,表结构更改后,该字段会被自动赋值,从1开始递增。我们回头再看看修改表结构之后的数据内容:

ajax技术如何同时向两个列数相同的表插入数据_数据库插入操作_mysql插入数据

没错,两条原本一模一样的数据,因为有了自增字段,终于变的不一样了。怎么删除,我相信绝大部分朋友就有大把的方法了,比如在MSSMS中选中行直接删除掉,还可以些删除的SQL脚本:

delete test where fid=2

数据库插入操作_ajax技术如何同时向两个列数相同的表插入数据_mysql插入数据

前面无法写脚本,是因为where后面的条件无从下手,现在有了唯一区分的字段就不一样了。

将数据表结构还原

表结构如何还原到原来的样子呢?很简单,进入表结构设计窗口,把前面新增的字段删除就行了,当然,您也可以写个删除字段的SQL脚本。删除后,看上去您似乎什么都没做,但冗余的数据却被您删除了,参看下图:

ajax技术如何同时向两个列数相同的表插入数据_mysql插入数据_数据库插入操作

忙活了半天,终于把重复数据删除了,您是庆幸自己把这活干完了、还是想着如何反省自己不要再犯这类错误呢?

杜绝此类问题的根本方法

杜绝此类问题的根本方法,就是创建表时,所有的表都要设置主键、设置主键、设置主键,重要的问题说三遍!没有主键的表,想想都是可怕的,不仅可能造成数据重复,而且查询效率极低。

当然,如果您忘了设置主键、不小心造成了数据完全一致无法删除,试试我前面的方法也未尝不可。

(编辑:武汉站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!