首页 > 数据库 > mysql教程 > 如何在没有唯一键的情况下删除 SQL Server 中的重复行?

如何在没有唯一键的情况下删除 SQL Server 中的重复行?

Susan Sarandon
发布: 2025-01-23 01:51:09
原创
906 人浏览过

How to Delete Duplicate Rows in SQL Server Without a Unique Key?

高效删除 SQL Server 中的重复行:CTE 方法

在处理缺少唯一键的 SQL Server 表时,消除重复行需要采取策略性方法。 使用公用表表达式 (CTE) 结合 ROW_NUMBER() 函数可以有效地实现这一点。

这是演示此技术的解决方案:

<code class="language-sql">WITH RowNumberedRows AS (
   SELECT [col1], [col2], [col3], [col4], [col5], [col6], [col7],
       RN = ROW_NUMBER() OVER (PARTITION BY col1 ORDER BY col1)
   FROM dbo.Table1
)
DELETE FROM RowNumberedRows
WHERE RN > 1;</code>
登录后复制

详细说明:

CTE,恰当地命名为 RowNumberedRows,为表中的每一行分配一个唯一的行号 (RN)。 ROW_NUMBER() 函数根据 col1 列对行进行分区,并在每个分区内分配顺序编号。 这可确保每个重复组的第一次出现的 RN 为 1。

然后,DELETE 语句以 CTE 为目标,删除 RN 大于 1 的所有行。这仅留下每个重复集的第一行,从而有效地删除重复项。

示例:

将此查询应用于示例数据会产生以下结果:

COL1 COL2 COL3 COL4 COL5 COL6 COL7
john 1 1 1 1 1 1
sally 2 2 2 2 2 2

观察到重复的“john”行已被成功消除。

该方法的适应性值得关注。通过调整 ROW_NUMBER() 函数中的分区列(例如 PARTITION BY col1, col2),您可以根据需要基于多个列定义唯一性。

以上是如何在没有唯一键的情况下删除 SQL Server 中的重复行?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板