mysql 中删除重复字段数据的方式

1、创建一张表

CREATE TABLE `user` (
  `id` int(11) DEFAULT NULL,
  `name` varchar(255) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  `address` varchar(255) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

2、插入对应数据

INSERT INTO `user` VALUES (‘1‘, ‘zhangsan‘, ‘20‘, ‘上海‘);
INSERT INTO `user` VALUES (‘2‘, ‘zhangsan‘, ‘20‘, ‘北京‘);
INSERT INTO `user` VALUES (‘3‘, ‘lisi‘, ‘25‘, ‘北京‘);
INSERT INTO `user` VALUES (‘4‘, ‘lisi‘, ‘25‘, ‘深圳‘);
INSERT INTO `user` VALUES (‘5‘, ‘wangwu‘, ‘30‘, ‘深圳‘);
INSERT INTO `user` VALUES (‘6‘, ‘wangwu‘, ‘30‘, ‘上海‘);
INSERT INTO `user` VALUES (‘7‘, ‘zhaoliu‘, ‘35‘, ‘广州‘);

3、常用操作

#复制一张表
CREATE TABLE `user` as SELECT * FROM `user_temp`
#创建一张空表
CREATE TABLE user_temp1 like `user`
#删除一张表
DROP TABLE `user`

4、使用借助count关键字

DELETE FROM `user` WHERE id in(
    SELECT v.minid FROM(
            SELECT COUNT(*) num,`name`,age,MAX(id) minid FROM `user` GROUP BY `name`,age
    ) v WHERE v.num>1
)

5、使用having关键字

DELETE FROM `user` WHERE id in(
    SELECT id FROM(
        SELECT MAX(id) id,`name`,age,address FROM `user` t GROUP BY t.`name` HAVING COUNT(`name`)>1
    ) v
)

注意:delete语句直接删除一条查询结果集是行不通的,必须借助内嵌视图也就是字查询来完成删除功能

原文地址:https://www.cnblogs.com/zhanh247/p/11415916.html

时间: 2024-08-29 16:00:53

mysql 中删除重复字段数据的方式的相关文章

MySQL中删除重复数据的简单方法,mysql删除重复数据

MYSQL里有五百万数据,但大多是重复的,真实的就180万,于是想怎样把这些重复的数据搞出来,在网上找了一圈,好多是用NOT IN这样的代码,这样效率很低,自己琢磨组合了一下,找到一个高效的处理方式,用这个方式,五百万数据,十来分钟就全部去除重复了,请各位参考. 第一步:从500万数据表data_content_152里提取出不重复的字段SFZHM对应的ID字段到TMP3表 create table tmp3 as select min(id) as col1 from data_content

Mysql 中删除重复数据(保留一条)

sql去重 先根据需要去重的字段进行分组,取到主键值最小的记录(id 是主键,删除重复的 record_id 的记录) select min(id) from tb_traffic_wf_record t group by t.record_id 然后删除不在上面的记录里的数据,就行了 delete from tb_traffic_wf_record where id not in (select min(id) from tb_traffic_wf_record as t group by t

MySQL中删除重复记录

工作中,我们经常有需要删除一些重复数据的这种需求.重复数据可能是程序bug造成的 好,让我们看看如何删除这些重复数据 删除重复数据的思路呢,是这样的,查看根据这个重复字段分组后的结果有没有大于1的情况如果有大于的1的情况呢,那就说明是有重复数据的! 1) 创建数据库 create database ceshi; 2) 创建表 CREATE TABLE t1 ( id int(10) unsigned NOT NULL AUTO_INCREMENT, name varchar(20) not nu

mysql中删除重复数据

//首先我们需要知道我们重复的都有哪些数据, //第一步:进行对数据表进行分组,group by. //第二步:进行后通过having进行限制筛选,条数大于等于2的 //第三步:进行多表删除. //案例: //第一步,进行对数据分组,并通过having进行限制筛选,获得存在重复数据老王,如下: //第二步,进行删除,请仔细看删除语句,我们把筛选出来的 AS t2 当做子表.来进行筛选. 例如id和id的下一位进行比较,如果name相同,就删除. //请仔细看下面这句代码,删除的关键 mysql>

MySQL中删除重复数据只保留一条

用SQL语句,删除掉重复项只保留一条 在几千条记录里,存在着些相同的记录,如何能用SQL语句,删除掉重复的呢 1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断 SELECT * FROM people WHERE peopleId IN ( SELECT peopleId FROM people GROUP BY peopleId HAVINGcount(peopleId) > 1 ) 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 1 2 3

C++中删除重复的数据并且输出(相当与shell脚本里面的sort -u)

//问题: //给你一个数组,a[]={1,1,1,1,1,2,2,2,2,3,3,3,4,5,6} //要输出的结果是1,2,3,4,5,6.(去除重复的数字,要求时间空间的考虑). #include <iostream> using namespace std; struct Node { int data; Node *next; Node():data(-1),next(NULL){} }; //时间复杂度大幅度减少,但是增加了一定的空间复杂度. class Hash { public

MySQL中删除数据的两种方法

转自:http://blog.csdn.net/apache6/article/details/2778878 在MySQL中有两种方法可以删除数据,一种是DELETE语句,另一种是TRUNCATE TABLE语句. DELETE语句可以通过WHERE对要删除的记录进行选择.而使用TRUNCATE TABLE将删除表中的所有记录.因此,DELETE语句更灵活. 如果要清空表中的所有记录,可以使用下面的两种方法: DELETE FROM table1 TRUNCATE TABLE table1 其

MSSQL如何在没有主键的表中删除重复数据

为了对重复数据进行实验,下面建一个设计不太好(没有主键)表并插入了一些重复数据: create database testdb use testdb ; go create table DupsNoPK (Col1 int Null, Col2 char(5) Null ); go insert DupsNoPK(Col1,Col2) Values(1,'abc'), (2,'abc'), (2,'abc'), (2,'abc'), (7,'xyz'), (7,'xyz'); 为了验证表确实有重

mySQL中删除unique key的语法 (删除某个字段的唯一性)

mySQL中删除unique key的语法 CREATE TABLE `good_booked` (  `auto_id` int(10) NOT NULL auto_increment,  `good_id` int(11) default NULL,  `chemist_id` int(11) default NULL,  PRIMARY KEY  (`auto_id`),  UNIQUE KEY `good_id` (`good_id`,`chemist_id`),  KEY `curre