问题描述
如何删除记录并为每个用户创建一个唯一记录。 这意味着可能有多个相同的记录,但不同的用户。一个用户不能有多个相同的记录。
例如,如果用户 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 );