|
|
|
| Приветствую! Требуется из таблицы `dc` удалить строки с одинаковыми значениями поля `url` (VARCHAR), но не все, а оставить одну. То есть, чтобы их значения не повторялись. Можно ли одним запросом? | |
|
|
|
|
|
|
|
для: amigo62
(11.10.2008 в 17:02)
| | delete from `dc` where id not in (select min(id) from `dc` group by url);
как то так должно быть верно... | |
|
|
|
|
|
|
|
для: mechanic
(11.10.2008 в 17:19)
| | мм, то есть - группирует по url, из каждой группы вытаскивает минимальный id, затем удаляет всех, у кого id больше минимального, правильно понял? | |
|
|
|
|
|
|
|
для: amigo62
(11.10.2008 в 17:36)
| | SQL-запрос:
DELETE FROM `dc` WHERE `id_dc` NOT IN (
SELECT MIN( `id_dc` )
FROM `dc`
GROUP BY `url`
)
Ответ MySQL:
#1093 - You can't specify target table 'dc' for update in FROM clause | |
|
|
|
|
|
|
|
для: amigo62
(11.10.2008 в 17:02)
| | Может лучше так
<?
//Подсчитываем кол-во строк с одинаковым значением поля url
$sql =mysql_query("select * from `dc` where `url` = $url");
$cnt = mysql_num_rows($sql);
//Вычитаем из общего кол-во строк с одинаковым полем url единицу
$lim = $cnt-1;
$limit = $cnt-$lim;
Выполняем запрос на удаление строк
$res = "DELETE FROM `dc` WHERE `url`=$url LIMIT $limit";
if(!mysql_query($res))
{
echo "Ошибка в".mysql_error();
}
else
{
echo "Строки удалены!";
}
?>
|
| |
|
|
|
|
|
|
|
для: ols
(11.10.2008 в 18:07)
| | В принципе была подобная мысль... Но $url может принимать очень много значений, и по идее это элемент массива, который создается по результатам еще одного запроса с параметром DISTINCT. Поэтому вместо одного запроса выйдет очень много :( | |
|
|
|