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

Форум MySQL

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

 

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

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

тема: SELECT COUNT(*) FROM tbl LIMIT 10
 
 автор: Евгений Петров   (20.05.2007 в 18:04)   письмо автору
 
 

SELECT COUNT(*) FROM tbl LIMIT 10
данный запрос не смотря на LIMIT 10 возвращает кол-во записей в таблице. Можно ли как то ограничить количество?

   
 
 автор: ddhvvn   (20.05.2007 в 18:25)   письмо автору
 
   для: Евгений Петров   (20.05.2007 в 18:04)
 

То есть???
Вы хотите получить количество, которое сами задаете?

   
 
 автор: Евгений Петров   (20.05.2007 в 18:30)   письмо автору
 
   для: ddhvvn   (20.05.2007 в 18:25)
 

На самом деле все сложнее, там довольно серьезный поиск по довольно серьезной базе происходит. Мне нужно общее количество сделать скажем 100 если оно превышает это значение а если меньше то меньше и выводить.

   
 
 автор: mefestofel   (20.05.2007 в 19:18)   письмо автору
 
   для: Евгений Петров   (20.05.2007 в 18:04)
 

> не смотря на LIMIT 10 возвращает кол-во записей в таблице
Вопрос не корректный, объясните понятнее...

   
 
 автор: Евгений Петров   (20.05.2007 в 19:30)   письмо автору
 
   для: mefestofel   (20.05.2007 в 19:18)
 

Ну по логике мне казалось что MySQL должен перестать считать строки после 10 т.к. стоит LIMIT 10 но он не делает этого а считает все строки

   
 
 автор: cheops   (20.05.2007 в 19:53)   письмо автору
 
   для: Евгений Петров   (20.05.2007 в 18:04)
 

Собственно с конструкцией LIMIT смысла нет возвращать значение 10, которое заранее известно - в случае любого другого запроса, ограничение будет действовать.

   
 
 автор: Евгений Петров   (20.05.2007 в 20:00)   письмо автору
 
   для: cheops   (20.05.2007 в 19:53)
 

Смысл есть тогда когда количество записей удоворяющих условию (в данном случае это общее число записей в таблице) меньше значения LIMIT. Т.е. если записей в таблице больше 10 то необходимо вернуть 10, если меньше то вывести сколько есть.

   
 
 автор: Trianon   (20.05.2007 в 22:08)   письмо автору
 
   для: Евгений Петров   (20.05.2007 в 20:00)
 

Конструкция LIMIT 10 вообще никак не ограничивает просматриваемые записи в БД. Она ограничивает лишь строки, выдаваемые в качестве конечного результата. Поскольку запрос SELECT COUNT(*) без группировки выведет одну и только одну строку - LIMIT теряет смысл.

Ограничить просматриваемые агрегатными функиями строки Вы можете только через указание WHERE.
Причем ограничиваться количеством там бессмысленно - поскольку порядок записей в таблицах не определен, и Вы не можете знать, первые 10 каких именно строк Вам выберут.

   
Rambler's Top100
вверх

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