高效删除 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中文网其他相关文章!