мне нужно удалить дубликаты из таблицы, которая выглядит следующим образом:Удаление дубликатов в базе данных SQL на состояние
id post_author post_title
-----------------------------------------------------------------------------
21319 1 Youngstown State University
20535 1 Yo San University of Traditional Chinese Medicine
30268 29 Yo San University of Traditional Chinese Medicine
29747 29 Yeshiva University
21964 1 Yale University
29247 29 Yale University
29497 29 Xavier University of Louisiana
21916 1 Xavier University
29862 29 Xavier University
29860 29 Wright State University-Main Campus
20915 1 Wright State University-Lake Campus
21562 1 World Mission University
30267 29 World Mission University
В принципе, если есть две записи с одинаковыми post_title
, мне нужно удалить одну с post_author = 1
, но если post_title
уникален, запись должна быть оставлена как есть.
Как это можно сделать с помощью SQL-запроса?
EDIT:
Я попробовал запрос, предложенный Mureinik. Запрос выглядит следующим образом:
DELETE t FROM wp_posts AS t
WHERE t.post_author = 1 AND
EXISTS (SELECT * FROM wp_posts s
WHERE t.post_title = s.post_title
AND s.post_authot != 1)
Но я получил ошибку:
[Err] 1093 - You can't specify target table 't' for update in FROM clause
Что я делаю неправильно?
это или нет? – Sherlock
Это на mysql или postgresql? –
Это удаление, мне нужно удалить дубликаты. Это для MySQL –