Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Запрос
Форумы портала PHP.SU » PHP » SQL и Архитектура БД » Запрос

Страниц (1): [1]
 

1. SAD - 29 Июня, 2013 - 09:28:25 - перейти к сообщению
Как объединить два запроса? для оптимизации. хотелось бы использовать данные из первого запроса для последующего поиска в них.

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT COUNT (*) FROM `countries` WHERE country IN (1,2,3,4,5,6)
  2.  
  3. SELECT COUNT (*) AS `S` FROM `countries` WHERE `pp` = 8 AND country IN (1,2,3,4,5,6)


Без временных таблиц.
2. Мелкий - 29 Июня, 2013 - 10:27:03 - перейти к сообщению
Т.е. количество country 1..6 и отдельно pp=8 среди них?

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT COUNT (*), sum(`pp` = 8) FROM `countries` WHERE country IN (1,2,3,4,5,6)

Однако надо тестировать в бою, два разных запроса могут оказаться эффективнее при наличии индекса по country & pp, т.к. sum будет просматривать все ряды, оставшиеся после where
3. SAD - 29 Июня, 2013 - 10:42:01 - перейти к сообщению
в firebird я бы написал так. sum(case when pp == 8 then 1 else 0). это равнозначно тому, что Вы написали?
4. Мелкий - 29 Июня, 2013 - 10:47:04 - перейти к сообщению
Да, оно самое. Мой вариант компактнее только из-за неявного приведения типов.
5. SAD - 29 Июня, 2013 - 10:48:54 - перейти к сообщению
а вот эта часть?
Цитата:
хотелось бы использовать данные из первого запроса для последующего поиска в них.
6. Мелкий - 29 Июня, 2013 - 11:02:29 - перейти к сообщению
Тогда поясните, что имеете в виду.
7. SAD - 29 Июня, 2013 - 11:09:15 - перейти к сообщению
Отобрать все записи + подсчитать их кол-во по условиям

 

Powered by ExBB FM 1.0 RC1