无需唯一标识符删除重复项:Netezza解决方案
在大型Netezza表中,如果没有唯一标识符,删除重复行可能是一项艰巨的任务。虽然提供的SQL查询在其他数据库中可能有效,但由于WITH语句后DELETE子句的限制,它在Netezza中会失败。
为了克服这一挑战,我们提出了一种利用USING关键字的替代方法。以下Netezza查询可以无缝删除重复行:
<code class="language-sql">DELETE FROM table_with_dups T1 USING table_with_dups T2 WHERE T1.ctid < T2.ctid AND T1.column1 = T2.column1 AND T1.column2 = T2.column2 -- ... add more AND conditions for other columns as needed ...</code>
以下是工作原理:
T1.ctid < T2.ctid
确保只删除重复行中的一行。在执行DELETE之前,您可以通过将DELETE替换为SELECT *并将USING替换为逗号(,)来查看重复项:
<code class="language-sql">SELECT * FROM table_with_dups T1, table_with_dups T2 WHERE T1.ctid < T2.ctid AND T1.column1 = T2.column1 AND T1.column2 = T2.column2 -- ... add more AND conditions for other columns as needed ...</code>
总而言之,此Netezza查询提供了一种高效的解决方案,用于在没有唯一标识符的情况下删除重复行,无需复杂的子查询或窗口函数。
以上是如何在没有唯一标识符的情况下删除 Netezza 中的重复行?的详细内容。更多信息请关注PHP中文网其他相关文章!