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

Форум MySQL

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

 

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

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

тема: Подсчёт при GROUP BY
 
 автор: Orc   (13.07.2008 в 13:31)   письмо автору
 
 

Допустим, есть каталог товаров, где каждый товар имеет свою марку - Nokia, Siemens и т.п.
Марки (бренды) в отдельной таблице, список товаров - в другой.

Нужно всё сгруппировать по маркам, я это делаю примерно так:
SELECT `b`.*, `p`.`brand_id`, COUNT(*) AS `products_q` FROM `products` `p`, `brand` `b`
WHERE `p`.`section_id` = 1 AND `p`.`brand_id` = `b`.`id` GROUP BY `p`.`brand_id` ORDER BY `b`.`name`;


Но мне нужна постараничная навигация, а для этого нужно знать количество марок (брендов), которые "засветились" в данном разделе каталога. Делаю довольно грубо вот так:

SELECT COUNT(*) FROM ( SELECT 0 FROM `products` `p`, `brand` `b`
WHERE `p`.`section_id` = 1 AND `p`.`brand_id` = `b`.`id` GROUP BY `p`.`brand_id` ) AS `t`;


Мне не нравится подобное решение...Нельзя ли обойтись без подзапроса?

   
 
 автор: Trianon   (13.07.2008 в 13:57)   письмо автору
 
   для: Orc   (13.07.2008 в 13:31)
 

SQL_CALC_ROWS()

   
 
 автор: Orc   (13.07.2008 в 15:53)   письмо автору
 
   для: Trianon   (13.07.2008 в 13:57)
 

> SQL_CALC_ROWS()

Такой функции не нашёл. Нашёл ключевое слово SQL_CALC_FOUND_ROWS и функцию FOUND_ROWS(), то есть придётся на два запроса тогда разделять...Не выйдет, пожалуй :(
Для снижения нагрузки на СУБД я кеширую результаты SQL-запросов. А подобное дробление запроса делает его (кеширование) невозможным.

Ну и на том спасибо.

   
 
 автор: Trianon   (13.07.2008 в 16:02)   письмо автору
 
   для: Orc   (13.07.2008 в 15:53)
 

>> SQL_CALC_ROWS()
>Такой функции не нашёл. Нашёл ключевое слово SQL_CALC_FOUND_ROWS

Угу. Опечатался.

   
Rambler's Top100
вверх

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