SQL Server删除重复数据只保留一条

介绍

最近在导入数据库数据, 有时候给的数据源文件,存在重复数据, 需要清除但是还需要保留一条记录的需求.

本文将介绍如何使用SQL Server来实现这个需求。

流程

下面是实现删除重复数据的流程,我们可以用表格展示每个步骤:

步骤 描述

步骤一 先看看有哪些重复的数据

步骤二 根据条件删除重复数据

SQL实现

步骤一:先看看有哪些重复的数据(根据条件分组)

首先,我们需要查询出所有重复数据,以便后续删除操作。以下是查询重复数据的代码:

sql 复制代码
SELECT col1, col2,  COUNT(*) AS count
FROM table_name
GROUP BY col1, col2
HAVING COUNT(*) > 1;

这段代码将会返回具有重复值的记录,并且还会显示重复次数。需要根据实际情况将 table_name 替换为你所使用的表名,col1, col2 替换为需要判断重复的列。

步骤二:根据条件删除重复数据

在查询出所有重复数据后,我们可以根据条件删除这些重复数据,只保留一条。以下是删除重复数据的代码:

sql 复制代码
WITH cte AS (
    SELECT col1, col2 ROW_NUMBER() OVER(PARTITION BY col1, col2  ORDER BY (SELECT 0)) AS rn
    FROM talbe_name
)
DELETE FROM cte
WHERE rn > 1;

这段代码使用了 ROW_NUMBER() 函数和一个公共表表达式(Common Table Expression,CTE)来为每条记录分配一个行号,并按照指定的列进行分组。最后,我们删除行号大于1的记录,即保留第一条记录,删除重复数据。

需要注意的是,同样需要根据实际情况将 table_name 替换为你所使用的表名,col1, col2 替换为需要判断重复的列。

相关推荐
FreeBuf_8 小时前
AWS服务大规模中断,基础设施故障影响全球企业
网络·数据库·aws
TG_yunshuguoji8 小时前
亚马逊云代理:AWS的EC2, S3, RDS,Lambda具体简介
服务器·云计算·aws
NineData8 小时前
NineData 数据库 DevOps 新增支持 PolarDB-X
数据库·devops·数据库管理工具·ninedata·polardb-x·sql审核·sql管理工具
王道长服务器 | 亚马逊云8 小时前
AWS CloudFormation —— 自动化部署的“云中脚本大师”
运维·服务器·网络·自动化·云计算·aws
christine-rr8 小时前
MySQL数据库管理、DDL、DQL、DML、DCL等总结
linux·数据库·mysql
观望过往8 小时前
非关系型数据库(NoSQL)学习指南:从入门到实战
数据库·nosql
Bruce_Liuxiaowei9 小时前
解决Kali虚拟机中VMnet1(仅主机模式)网卡无法获取IP地址的问题
运维·网络·网络协议·tcp/ip
key_Go9 小时前
12.docker swarm
运维·docker·容器·docker swarm
Quz9 小时前
QML TableView:基于SQLite实现增删改查
数据库·qt·sqlite
馨谙9 小时前
SSH密钥认证:从密码到密钥的安全升级指南
运维·安全·ssh