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

Форум MySQL

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

 

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

вид форума:
Линейный форум (новые сообщения вниз) Структурный форум

тема: UNION COUNT

Сообщения:  [1-7] 

 
 автор: ride   (13.11.2010 в 16:56)   письмо автору
 
   для: Trianon   (13.11.2010 в 16:53)
 

согласен, но отредактировать уже не могу.

  Ответить  
 
 автор: Trianon   (13.11.2010 в 16:53)   письмо автору
 
   для: ride   (13.11.2010 в 16:37)
 

число лишних фигурных скобок в два раза больше числа недостающих квадратных...

  Ответить  
 
 автор: ride   (13.11.2010 в 16:37)   письмо автору
 
   для: gOFREe   (13.11.2010 в 16:02)
 

$count должен быть рез-том функции mysql_query - то есть, типа resource.

а по поводу вашей задачи - можно сделать примерно так

$cnt = array(1 => 0, 0, 0);
$result = mysql_query("SELECT ball, COUNT(*) as `cnt` FROM `otziv` where ball in (".implode(",", array_keys($cnt)).") group by ball");
while($row = mysql_fetch_assoc($result)) {
    $cnt[$row['ball'] = $row['cnt'];
}

print_r($cnt);

  Ответить  
 
 автор: gOFREe   (13.11.2010 в 16:02)   письмо автору
 
   для: ride   (13.11.2010 в 14:48)
 

да string.

Сделал как вы написали.
Вывод данных такой, правильно?

$b1 = mysql_result($count,0,'b');
$b2 = mysql_result($count,1,'b');
$b3 = mysql_result($count,2,'b');

  Ответить  
 
 автор: ride   (13.11.2010 в 14:48)   письмо автору
 
   для: gOFREe   (13.11.2010 в 14:24)
 

у вас $count типа string?

запрос можно написать так
SELECT COUNT(*) as `b` FROM `otziv` group by ball

  Ответить  
 
 автор: Trianon   (13.11.2010 в 14:48)   письмо автору
 
   для: gOFREe   (13.11.2010 в 14:24)
 

алиасы соответствующих столбцов должны совпадать. (Впрочем MySQL читает алиас первого SELECT.)
UNION копит строки, а не столбцы.
Зачем вообще UNION на несвязанных данных?

И таки да, ride верно замечает - что именно в $count?
Запрос или ресурс резалт-сета?

  Ответить  
 
 автор: gOFREe   (13.11.2010 в 14:24)   письмо автору
 
 

Почему на этот запрос выводит ошибку?

$count = "
       SELECT COUNT(`ball`) as `b1` FROM `otziv` WHERE  ball = '1' 
union SELECT COUNT(`ball`) as `b2` FROM `otziv` WHERE  ball = '2'
union SELECT COUNT(`ball`) as `b3` FROM `otziv` WHERE  ball = '3'";



При таком выводе

$b1 = mysql_result($count,0,'b1');
$b2 = mysql_result($count,0,'b2');
$b3 = mysql_result($count,0,'b3');


Warning: mysql_result() [function.mysql-result]: b2 not found in MySQL result index 12
Warning: mysql_result() [function.mysql-result]: b3 not found in MySQL result index 12

первый результат выводит правильно.

  Ответить  

Сообщения:  [1-7] 

Форум разработан IT-студией SoftTime
Rambler's Top100
вверх

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