如何在 postgresql 中为每个用户删除一条重复记录

问题描述

如何删除记录并为每个用户创建一个唯一记录。 这意味着可能有多个相同的记录,但不同的用户一个用户不能有多个相同的记录。

例如,如果用户 1 搜索蜘蛛侠电影,那么这是一个唯一记录, 但是如果他们再次用相同的名字搜索蜘蛛侠没有区别然后删除第二个 记录。现在,如果用户 2 搜索相同的蜘蛛侠电影,则保留该记录,因为用户 2 的用户 ID 与用户 1 不同,依此类推。

我的问题是如何删除用户记录并为每个用户只保留一个唯一记录。

我使用两个不同的表来跟踪用户并将他们与电影表进行匹配

我想删除用户表和电影表中对用户不唯一的电影。

这是我的桌子

https://i.stack.imgur.com/yrc97.png

DELETE FROM movie_media t1
            USING accountMovie t2
            WHERE id IN
                (SELECT id
                FROM 
                (SELECT id,ROW_NUMBER() OVER( PARTITION BY title
                ORDER BY id) AS row_num
                FROM movie_media ) t
                WHERE t.row_num > 1)
                AND t2."accountId" = $1

我正在寻找这样的东西我知道代码不起作用我试图传达我对我正在寻找的东西的总体想法

解决方法

您要做的第一件事是在插入之前检查重复记录。我在代码级别执行此操作,但您也可以在数据库级别执行此操作。一盎司的预防胜过一磅的治疗!

如果我正确理解您的表格,您应该可以使用它来删除重复的行:

DELETE FROM movie
WHERE id IN
    (SELECT id
    FROM 
        (SELECT id,ROW_NUMBER() OVER( PARTITION BY id,mediaId
        ORDER BY  id ) AS row_num
        FROM movie ) t
        WHERE t.row_num > 1 );