|
|
|
|
SELECT COUNT(*) FROM tbl LIMIT 10
| данный запрос не смотря на LIMIT 10 возвращает кол-во записей в таблице. Можно ли как то ограничить количество? | |
|
|
|
|
|
|
|
для: Евгений Петров
(20.05.2007 в 18:04)
| | То есть???
Вы хотите получить количество, которое сами задаете? | |
|
|
|
|
|
|
|
для: ddhvvn
(20.05.2007 в 18:25)
| | На самом деле все сложнее, там довольно серьезный поиск по довольно серьезной базе происходит. Мне нужно общее количество сделать скажем 100 если оно превышает это значение а если меньше то меньше и выводить. | |
|
|
|
|
|
|
|
для: Евгений Петров
(20.05.2007 в 18:04)
| | > не смотря на LIMIT 10 возвращает кол-во записей в таблице
Вопрос не корректный, объясните понятнее... | |
|
|
|
|
|
|
|
для: mefestofel
(20.05.2007 в 19:18)
| | Ну по логике мне казалось что MySQL должен перестать считать строки после 10 т.к. стоит LIMIT 10 но он не делает этого а считает все строки | |
|
|
|
|
|
|
|
для: Евгений Петров
(20.05.2007 в 18:04)
| | Собственно с конструкцией LIMIT смысла нет возвращать значение 10, которое заранее известно - в случае любого другого запроса, ограничение будет действовать. | |
|
|
|
|
|
|
|
для: cheops
(20.05.2007 в 19:53)
| | Смысл есть тогда когда количество записей удоворяющих условию (в данном случае это общее число записей в таблице) меньше значения LIMIT. Т.е. если записей в таблице больше 10 то необходимо вернуть 10, если меньше то вывести сколько есть. | |
|
|
|
|
|
|
|
для: Евгений Петров
(20.05.2007 в 20:00)
| | Конструкция LIMIT 10 вообще никак не ограничивает просматриваемые записи в БД. Она ограничивает лишь строки, выдаваемые в качестве конечного результата. Поскольку запрос SELECT COUNT(*) без группировки выведет одну и только одну строку - LIMIT теряет смысл.
Ограничить просматриваемые агрегатными функиями строки Вы можете только через указание WHERE.
Причем ограничиваться количеством там бессмысленно - поскольку порядок записей в таблицах не определен, и Вы не можете знать, первые 10 каких именно строк Вам выберут. | |
|
|
|