技术文摘
MySQL 怎样删除表中重复行并保留较小(或较大)id 的记录
MySQL 怎样删除表中重复行并保留较小(或较大)id 的记录
在使用 MySQL 数据库时,经常会遇到表中存在重复行的情况,这不仅会占用额外的存储空间,还可能影响数据的准确性和查询性能。此时,我们需要删除这些重复行,同时根据业务需求保留较小或较大 id 的记录。下面就来详细探讨如何实现这一操作。
1. 保留较小 id 的记录
我们创建一个示例表 test_table,其中包含 id、name 和 email 字段。
CREATE TABLE test_table (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(255),
email VARCHAR(255)
);
插入一些测试数据,其中包含重复行。
INSERT INTO test_table (name, email) VALUES
('Alice', 'alice@example.com'),
('Bob', 'bob@example.com'),
('Alice', 'alice@example.com');
要删除重复行并保留较小 id 的记录,可以使用以下方法。
子查询法
DELETE FROM test_table
WHERE id NOT IN (
SELECT min_id
FROM (
SELECT MIN(id) AS min_id
FROM test_table
GROUP BY name, email
) AS subquery
);
在这个查询中,内部子查询首先按 name 和 email 分组,并找出每组中的最小 id。然后,外部查询删除那些 id 不在这些最小 id 集合中的记录。
2. 保留较大 id 的记录
保留较大 id 的记录与保留较小 id 的记录方法类似。
子查询法
DELETE FROM test_table
WHERE id NOT IN (
SELECT max_id
FROM (
SELECT MAX(id) AS max_id
FROM test_table
GROUP BY name, email
) AS subquery
);
这里内部子查询按 name 和 email 分组,并找出每组中的最大 id。外部查询则删除那些 id 不在这些最大 id 集合中的记录。
3. 总结
通过上述方法,我们可以轻松地在 MySQL 中删除表中的重复行,并根据需求保留较小或较大 id 的记录。在实际应用中,需要根据表结构和业务逻辑来选择合适的方法。在执行删除操作前,务必做好数据备份,以防误操作导致数据丢失。掌握这些技巧,能够帮助我们更高效地管理和优化 MySQL 数据库,提升数据质量和系统性能。
TAGS: 删除重复行 MySQL重复行处理 保留较小id记录 保留较大id记录
- IDC 预测:未来五年程序员增长 50%,超半 500 强企业将卖软件
- 阿里在云上 Java 领域,若拼不过 GO 该如何重塑
- Python 助力构建简单系统监控图表
- JS 助力实现多种图片相似度算法
- 我快速读书的秘诀:主靠“猜”!
- 5 款 IT 基础设施必备自动化工具
- Python 中参数化测试的实现方法
- Python 助力工作中的“偷懒”之道
- 8 个计算机视觉深度学习常见 Bug
- Python 打造天猫商品价格监督器,告别双十二涨价担忧
- HTTPS 使用的是对称加密还是非对称加密,你知道吗?
- 互联网大厂空运至印度的年轻人
- 你使用的编程语言流行排行,快来瞧!莫被时代抛下
- 数据科学家必知的 5 种图算法
- 怎样构建高效 DevOps 工具链