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

Форум MySQL

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

 

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

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

тема: Глюки с запросом

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

 
 автор: Trivium   (11.07.2010 в 15:58)   письмо автору
 
   для: Trianon   (03.07.2010 в 23:07)
 

А можно пример?)

  Ответить  
 
 автор: Trianon   (03.07.2010 в 23:07)   письмо автору
 
   для: Trivium   (03.07.2010 в 22:13)
 

составить простой группирующий запрос над той самой "другой" таблицей. Одной единственной в запросе, определяющем count() для каждого значения `prices`.`catid`.



И лишь потом его результат помещать в секцию FROM целевого запроса.

  Ответить  
 
 автор: Trivium   (03.07.2010 в 22:13)   письмо автору
 
   для: Trianon   (03.07.2010 в 01:21)
 

А как выразить условие допустим выбрать только те у которых в другой таблице count > 0 ?

  Ответить  
 
 автор: Trianon   (03.07.2010 в 01:21)   письмо автору
 
   для: sms-send   (03.07.2010 в 00:55)
 

>Я отвечал на фразу автора:
>
>> Надо выбрать из таблицы appearance все записи для которых количество записей в таблице prices > 0

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

  Ответить  
 
 автор: sms-send   (03.07.2010 в 00:55)   письмо автору
 
   для: Trianon   (03.07.2010 в 00:27)
 

Я отвечал на фразу автора:

> Надо выбрать из таблицы appearance все записи для которых количество записей в таблице prices > 0

Сейчас взглянул внимательней на запрос, по чему группируется, что передано в count, не берусь вообще что либо утверждать.
Единственный вариант (о котором мне известно), когда выражение count(prices.`priceId`) может вернуть "0" для группы, - это наличие null в обсчитываемом столбце, в озвученной задаче про этот момент ничего не сказано.

  Ответить  
 
 автор: Trianon   (03.07.2010 в 00:27)   письмо автору
 
   для: sms-send   (02.07.2010 в 23:35)
 

какое именно условие - лишнее, то есть такое, изъятие коего не повлияет ни при каких обстоятельствах на результат?

PS. Понимаю, что вопрос звучит абсурдно, учитывая нарушения семантики в SQL-запросе..
Но тем не менее. Ошибки можно поправить по вкусу.

  Ответить  
 
 автор: sms-send   (02.07.2010 в 23:35)   письмо автору
 
   для: Trianon   (02.07.2010 в 22:58)
 

Не шутка. А что? Я как то не так выразился? Или что то не то выразил?

  Ответить  
 
 автор: Trianon   (02.07.2010 в 22:58)   письмо автору
 
   для: sms-send   (02.07.2010 в 21:40)
 

Э?
Это шутка, не так ли?


PS. to Trivium .

А вот пара висящих полей в разделе SELECT - `appearance`.`mail` , `appearance`.`catid` - делают запрос семантически неоднозначным.

  Ответить  
 
 автор: sms-send   (02.07.2010 в 21:40)   письмо автору
 
   для: Trivium   (02.07.2010 в 20:48)
 

INNER JOIN и так возьмёт только те строки таблицы `appearance`, которым есть соответствия в присоединяемых таблицах, так что условие лишнее.

  Ответить  
 
 автор: Trianon   (02.07.2010 в 21:35)   письмо автору
 
   для: Trivium   (02.07.2010 в 20:48)
 

так запрос-то агрегатный?
where управляет тем, какие строки подсовывать count() и другим агрегатным функциям.
и исполняется тогда, когда totalcount (значение агрегата) еще не посчитано.

Может Вы с HAVING перпутали?

  Ответить  

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

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

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