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

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Помогите объединить запросы SELECT COUNT

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Без описания
A.B.C.
Отправлено: 05 Марта, 2012 - 12:32:49
Post Id



Новичок


Покинул форум
Сообщений всего: 47
Дата рег-ции: Март 2010  


Помог: 0 раз(а)




PHP:
скопировать код в буфер обмена
  1. "SELECT  COUNT(*) FROM `".$tab1."`  WHERE `id1`='".(int)$_SESSION['id']."' UNION ALL
  2.          SELECT  COUNT(*) FROM `".$tab2."` WHERE `id2`='".(int)$_SESSION['id']."'");
  3.  


нужно получить общее число елементов
 
 Top
OrmaJever Модератор
Отправлено: 05 Марта, 2012 - 13:07:40
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




PHP:
скопировать код в буфер обмена
  1. "SELECT  COUNT(*) as c1 FROM `".$tab1."`  WHERE `id1`='".(int)$_SESSION['id']."' UNION ALL
  2.         SELECT  COUNT(*) as c2 FROM `".$tab2."` WHERE `id2`='".(int)$_SESSION['id']."'");
  3. // ...
  4.  
  5. $row['c1'] + $row['c2'];
  6.  


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
A.B.C.
Отправлено: 05 Марта, 2012 - 13:13:41
Post Id



Новичок


Покинул форум
Сообщений всего: 47
Дата рег-ции: Март 2010  


Помог: 0 раз(а)




OrmaJever

Спасибо Вам большое.
(Добавление)
OrmaJever
А как думаете такой запрос быстрее будет чем два простых?
 
 Top
OrmaJever Модератор
Отправлено: 05 Марта, 2012 - 13:24:08
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




Даже незнаю, вроде бы union Работает медленее, хотя могу и ошибатся. Вобще можно такой запрос попробовать
PHP:
скопировать код в буфер обмена
  1. "SELECT  SUM(COUNT(`a`.`id1`), COUNT(`b`.`id2`)) as `sum` FROM `{$tab1}` as `a` LEFT JOIN `{$tab2}` as `b` ON `a`.`id1` = `b`.`id2` WHERE `id1`='".(int)$_SESSION['id']."'"


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
A.B.C.
Отправлено: 05 Марта, 2012 - 13:26:54
Post Id



Новичок


Покинул форум
Сообщений всего: 47
Дата рег-ции: Март 2010  


Помог: 0 раз(а)




Спасибо еще раз! Потестирую сейчас.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Работа с СУБД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB