Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Удаление записей с повторяющимеся данными
Форумы портала PHP.SU » » Работа с СУБД » Удаление записей с повторяющимеся данными

Страниц (1): [1]
 

1. NeuroZ - 24 Января, 2014 - 12:52:30 - перейти к сообщению
Есть таблица в которой повторяются данные в колонке virtuemart_product_id. Я хотел бы удалить ВСЕ записи, оставив только по одной уникальной записи для каждого значения virtuemart_product_id.

Лазил, читал, советуют похожую конструкцию:
CODE (SQL):
скопировать код в буфер обмена
  1. DELETE FROM virtuemart_product_manufacturers WHERE virtuemart_product_id IN (SELECT virtuemart_product_id FROM virtuemart_product_manufacturers t1  WHERE EXISTS
  2. (SELECT * FROM virtuemart_product_manufacturers t2 WHERE t2.id < t1.id AND t2.virtuemart_product_id = t1.virtuemart_product_id) )

Но она не работает Недовольство, огорчение

Пишет следующую ошибку:
You can't specify target table 'virtuemart_product_manufacturers' for update in FROM clause

Помогите разобраться с проблемой...
2. eai - 24 Января, 2014 - 12:58:07 - перейти к сообщению
Ты там поосторожнее а то сейчас все записи похеришь которые больше одного раза
3. NeuroZ - 24 Января, 2014 - 13:04:37 - перейти к сообщению
eai пишет:
Ты там поосторожнее а то сейчас все записи похеришь которые больше одного раза

1. Так в этом и весь смысл. Удалить все записи, где повторяется virtuemart_product_id
2. Предварительно я создал бэкап таблицы. Так что все ок)

 

Powered by ExBB FM 1.0 RC1