MySQL 过滤掉重复数据

问题:由于bug存在,导致数据库存在重复数据的问题,需要去除多余重复数据,仅保留一条有效数据

1.建立测试环境

DROP TABLE IF EXISTS `student`;
CREATE TABLE `student` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(20) COLLATE utf8_bin DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
-- Records of student
-- ----------------------------
INSERT INTO `student` VALUES ('1', 'cat', '12');
INSERT INTO `student` VALUES ('2', 'dog', '13');
INSERT INTO `student` VALUES ('3', 'camel', '25');
INSERT INTO `student` VALUES ('4', 'cat', '32');
INSERT INTO `student` VALUES ('5', 'dog', '42');
INSERT INTO `student` VALUES ('6', 'dog', '42');

查看重复数据情况

SELECT name,count( 1 ) 
FROM
 student 
GROUP BY
NAME 
HAVING
 count( 1 ) > 1;
、、、、、、、、结果、、、、、、、、
cat	2
dog	3

2.查出需要保留的重复数据

select min(rownum),id from (
SELECT
	@rownum :=@rownum + 1 AS rownum,
	s.*
FROM
	student s,
	(SELECT @rownum := 0) t
) st
GROUP BY st.`name` ORDER BY st.rownum

、、、、、、、、结果、、、、、、、、、、
1	1
2	2
3	3

因为表有可能不是递增形式的所以可能需要预先给予序号。mysql数据库表是没有rownum属性的,而Oracle是有的。rownum是自定义变量,表示行号。

3.删除重复数据

DELETE
FROM
	student
WHERE
	student.id NOT IN (
		SELECT
			x.id
		FROM
			(
				SELECT
					min(rownum),
					id
				FROM
					(
						SELECT
							@rownum :=@rownum + 1 AS rownum,
							s.*
						FROM
							student s,
							(SELECT @rownum := 0) t
					) st
				GROUP BY
					st.`name`
				ORDER BY
					st.rownum
			) x
	)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值