iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL怎么消除重复行
  • 685
分享到

MySQL怎么消除重复行

2024-04-02 19:04:59 685人浏览 薄情痞子
摘要

这篇文章将为大家详细讲解有关Mysql怎么消除重复行,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。sql语句 ----------------全部字段重复--------

这篇文章将为大家详细讲解有关Mysql怎么消除重复行,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

sql语句


----------------全部字段重复------------------------
 --1使用表替换来删除重复项
 create table test_1(id int,value int);
 insert test_1 select 1,2 uNIOn all select 1,2 union all select 2,3;
 --建立一个和源表结构一样的空的临时表
 create table tmp like test_1;
 --向临时表插入不重复的记录
 insert tmp select distinct * from test_1;
 --删除原表
 drop table test_1;
 --更改临时表名为目标表
 rename table tmp to test_1;
 --显示
 mysql> select * from test_1;
+------+-------+
| id  | value |
+------+-------+
|  1 |   2 |
|  2 |   3 |
+------+-------+
 --2.添加auto_increment属性列(这个方法只能用于MyISAM或者BDB引擎的表)
 create table test_1(id int,value int) engine=MyISAM;
 insert test_1 select 1,2 union all select 1,2 union all select 2,3;
 alter table test_1 add id2 int not null auto_increment,
 add primary key(id,value,id2);
 select * from test_1;
+----+-------+-----+
| id | value | id2 |
+----+-------+-----+
| 1 |   2 |  1 |
| 1 |   2 |  2 |
| 2 |   3 |  1 |
+----+-------+-----+
  delete from test_1 where id2<>1;
  alter table test_1 drop id2;
  select * from test_1;
  +----+-------+
| id | value |
+----+-------+
| 1 |   2 |
| 2 |   3 |
+----+-------+
-------------------部分字段重复---------------------
--1.加索引的方式
 create table test_2(id int,value int);
 insert test_2 select 1,2 union all select 1,3 union all select 2,3;
 Alter IGNORE table test_2 add primary key(id);
 select * from test_2;
 +----+-------+
| id | value |
+----+-------+
| 1 |   2 |
| 2 |   3 |
+----+-------+
 我们可以看到 1 3 这条记录消失了 
 我们这里也可以使用Unique约束 因为有可能列中有NULL值,但是这里NULL就可以多个了..
 --2.联合表删除
 create table test_2(id int,value int);
 insert test_2 select 1,2 union all select 1,3 union all select 2,3;
 delete A from test_2 a join (select MAX(value) as v ,ID from test_2 group by id) b
 on a.id=b.id and a.value<>b.v;
 select * from test_2;
 +------+-------+
| id  | value |
+------+-------+
|  1 |   3 |
|  2 |   3 |
+------+-------+
--3.使用Increment_auto也可以就是上面全部字段去重的第二个方法
--4.容易错误的方法
--有些朋友可能会想到子查询的方法,我们来试验一下
 create table test_2(id int,value int);
 insert test_2 select 1,2 union all select 1,3 union all select 2,3;
 delete a from test_2 a where exists(select * from test_2 where a.id=id and a.value<value);
 
 
 目前,您不能从一个表中删除,同时又在子查询中从同一个表中选择。
 
 
 ------------------删除特定重复行--------------
 --主要通过order by +limit 或者直接limit 
 create table test_3(id int,value int);
 insert test_3 select 1,2 union all select 1,3 union all select 1,4 union all select 2,3;
 --这是要保留ID=1 value最小的那个记录,删除其他id为的记录
 delete from test_3 where id=1 order by value desc limit 2;
 select * from test_3;
+------+-------+
| id  | value |
+------+-------+
|  1 |   2 |
|  2 |   3 |
+------+-------+
 如果你只想删除任意的记录 保留一条 就可以去掉order by

关于“MySQL怎么消除重复行”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL怎么消除重复行

本文链接: https://www.lsjlt.com/news/54620.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL怎么消除重复行
    这篇文章将为大家详细讲解有关MySQL怎么消除重复行,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。sql语句 ----------------全部字段重复--------...
    99+
    2024-04-02
  • mysql中怎么用distinct消除重复行
    在MySQL中,可以使用DISTINCT关键字来消除查询结果中的重复行。例如: SELECT DISTINCT column...
    99+
    2024-04-22
    mysql
  • MySQL如何消除重复行
    这篇文章给大家分享的是有关MySQL如何消除重复行的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。sql语句 ----------------全部字段重复-------------...
    99+
    2024-04-02
  • mysql怎么消除重复行的关键字
    在MySQL中,可以使用关键字DISTINCT来消除重复行。例如,假设有一个名为employees的表,包含以下数据:```+---...
    99+
    2023-09-29
    mysql
  • 怎么在mysql中删除重复行
    今天就跟大家聊聊有关怎么在mysql中删除重复行,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。表relation create ...
    99+
    2024-04-02
  • oracle怎么消除重复数据
    非常抱歉,由于您没有提供文章标题,我无法为您生成一篇高质量的文章。请您提供文章标题,我将尽快为您生成一篇优质的文章。...
    99+
    2024-05-21
  • php数组怎么消除重复值
    在PHP开发中,数组是非常常用的一种数据类型。有时候,我们需要从一个数组中提取出不重复的值,这时候就需要用到去重操作了。PHP提供了多种方式可以对数组进行去重操作。一、使用array_unique()函数array_unique()函数是P...
    99+
    2023-05-19
  • SQLServe中怎么删除重复行
    SQLServe中怎么删除重复行,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Microsoft SQL Server 表不应该包含重复行...
    99+
    2024-04-02
  • Linux中怎么删除重复行
    这篇文章给大家介绍Linux中怎么删除重复行,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。第一,用sort+uniq,注意,单纯uniq是不行的。sort -n test.txt |&nb...
    99+
    2023-06-13
  • MySQL数据库中怎么查找删除重复行
    这篇文章给大家介绍MySQL数据库中怎么查找删除重复行,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。当你对b字段排序(分组),相同值的c被分到不同的组,因此不能用COUNT(DISTI...
    99+
    2024-04-02
  • mysql怎么去除重复数据
    在MySQL中,你可以使用DISTINCT关键字来去除重复数据。 例如,假设你有一个名为employees的表,其中有一列为name...
    99+
    2024-04-09
    mysql
  • mysql怎么删除重复数据
    这篇文章主要讲解了“mysql怎么删除重复数据”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql怎么删除重复数据”吧!sku对应的重量表,应该一个sk...
    99+
    2024-04-02
  • MySQL 如何查找删除重复行
    目录一、如何查找重复行二、如何删除重复行三、如何查找多列上的重复四、错误的查询语句五、几种正确的方法一、如何查找重复行 第一步是定义什么样的行才是重复行。多数情况下很简单:它们某一...
    99+
    2024-04-02
  • SQL Server中怎么删除重复行
    今天就跟大家聊聊有关SQL Server中怎么删除重复行,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1.如果有ID字段,就是具有唯一性的字段复制代...
    99+
    2024-04-02
  • mysql中怎么删除重复数据
    在MySQL中,可以使用以下两种方法来删除重复数据: 方法1:使用DISTINCT关键字和INSERT INTO SELECT...
    99+
    2024-04-09
    mysql
  • java怎么消除数组中重复出现的值
    可以使用Set来消除数组中重复出现的值。Set是一个不允许有重复元素的集合,可以用来存储数组中的元素,然后再将Set转换回数组。以下...
    99+
    2023-10-20
    java
  • python 去除重复行
    from pandas import read_csv; df = read_csv('D://PA//4.3//data.csv') newDF = df.drop_duplicates(); ...
    99+
    2023-01-31
    python
  • Python删除重复行代码怎么写
    在Python中,可以使用以下方法删除重复行代码:1. 使用set()函数:将代码行放入一个set集合中,因为set集合中只包含唯一...
    99+
    2023-09-13
    Python
  • 怎么在mysql中去除重复数据
    在mysql中去除重复数据的方法:1.启动mysql;2.登录mysql数据库;3.进入数据表;4.使用COUNT函数统计重复数据;5.执行命令删除重复数据;具体步骤如下:首先,在命令行中启动mysql服务;service mys...
    99+
    2024-04-02
  • mysql中distinct怎么去除重复数据
    在MySQL中,可以使用DISTINCT关键字来去除重复数据。 例如,假设我们有一个名为"students"的表...
    99+
    2024-04-09
    mysql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作