Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Удалить более двадцати записей
 
 автор: Shorr Kan   (10.03.2006 в 11:07)   письмо автору
 
 

Мне нужно удалить из таблицы все записи, кроме первой двадцатки. "Первость" выясняется ORDER BY p DESC - т.е., где p более всего - двадцать строк оставить. Все остальные - удалить. По идее - как-то DELETE FROM tbl LIMIT 20,max(id) - но я не уверен. Подскажете?

   
 
 автор: Trianon   (10.03.2006 в 11:14)   письмо автору
 
   для: Shorr Kan   (10.03.2006 в 11:07)
 

В delete LIMIT не имеет второго параметра, и ограничивает только количество. Задача похожа на недавно обсуждавшуюся здесь.

   
 
 автор: cheops   (10.03.2006 в 11:41)   письмо автору
 
   для: Shorr Kan   (10.03.2006 в 11:07)
 

Нет, тактика должна быть такой
DELETE FROM tbl ORDER BY p LIMIT num

Где num = max(id) - 20, причём max(id) предварительно вычисляется дополнительным запросом.

   
 
 автор: Shorr Kan   (10.03.2006 в 11:55)   письмо автору
 
   для: cheops   (10.03.2006 в 11:41)
 

Так мне ж не по id надо удалять... мне надо удалять тех, у кого p меньше... и оставить двадцать лидеров.

$c=mysql_fetch_array(mysql_query("SELECT COUNT(id) FROM tbl;"));
if($c[0]>100){
$a=$c[0]-100;
mysql_query("DELETE FROM tbl ORDER BY p ASC LIMIT $a;");
}


сработает ведь?

   
 
 автор: cheops   (10.03.2006 в 12:24)   письмо автору
 
   для: Shorr Kan   (10.03.2006 в 11:55)
 

Да id здесь вообще можно не использовать, т.е. использовать COUNT(*), да ваш код должен работать корректно.

   
 
 автор: Trianon   (10.03.2006 в 12:42)   письмо автору
 
   для: Shorr Kan   (10.03.2006 в 11:55)
 

А что должен делать код в ситуации, когда в таблице с 15 по 25 строку p имеет одно и то же значение?

   
 
 автор: Shorr Kan   (10.03.2006 в 13:31)   письмо автору
 
   для: Trianon   (10.03.2006 в 12:42)
 

Он же всё равно его как-то отордерит, правильно?

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования