Как удалить из избранных в MySQL? - PullRequest
72 голосов
/ 30 декабря 2010

Этот код не работает для MySQL 5.0, как переписать его, чтобы он работал

DELETE FROM posts where id=(SELECT id FROM posts GROUP BY id  HAVING ( COUNT(id) > 1 ))

Я хочу удалить столбцы, которые не имеют уникального идентификатора.Я добавлю, что большую часть времени это только один идентификатор (я пробовал использовать синтаксис in, и он тоже не работает).

Ответы [ 4 ]

177 голосов
/ 30 декабря 2010

SELECT (под) запросы возвращают результат устанавливает . Поэтому вам нужно использовать IN, а не = в вашем предложении WHERE.

Кроме того, как показано в в этом ответе , вы не можете изменить ту же таблицу из подзапроса в том же запросе. Однако вы можете либо SELECT затем DELETE в отдельных запросах, либо вложить другой подзапрос и присвоить псевдоним внутреннему результату подзапроса (хотя это выглядит довольно странно):

DELETE FROM posts WHERE id IN (
    SELECT * FROM (
        SELECT id FROM posts GROUP BY id HAVING ( COUNT(id) > 1 )
    ) AS p
)

Или используйте соединения , как предложено Mchl .

20 голосов
/ 30 декабря 2010
DELETE 
  p1
  FROM posts AS p1 
CROSS JOIN (
  SELECT ID FROM posts GROUP BY id HAVING COUNT(id) > 1
) AS p2
USING (id)
3 голосов
/ 31 марта 2017

Вы можете использовать внутреннее соединение:

DELETE 
    ps 
FROM 
    posts ps INNER JOIN 
         (SELECT 
           distinct id 
         FROM 
             posts 
         GROUP BY id  
      HAVING COUNT(id) > 1 ) dubids on dubids.id = ps.id  
0 голосов
/ 10 октября 2013

Если вы хотите удалить все дубликаты, но по одному из каждого набора дубликатов, это одно из решений:

DELETE posts
FROM posts
LEFT JOIN (
    SELECT id
    FROM posts
    GROUP BY id
    HAVING COUNT(id) = 1

    UNION

    SELECT id
    FROM posts
    GROUP BY id
    HAVING COUNT(id) != 1
) AS duplicate USING (id)
WHERE duplicate.id IS NULL;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...