Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Максимальное значение среди столбцов одной строки. 
:(
    Опции темы
Jiffi
Дата 15.3.2012, 10:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 38
Регистрация: 2.6.2006

Репутация: нет
Всего: нет



Есть группа товаров

Код

id    |title        |fild1    |fild2    |fild3    |fild4    |fild5
1    |Заголовок1    |1        |4        |7        |6        |1
2    |Заголовок2    |3        |0        |4        |2        |0
3    |Заголовок3    |0        |5        |1        |9        |3
4    |Заголовок4    |8        |9        |0        |0        |7
5    |Заголовок5    |2        |1        |3        |3        |2
6    |Заголовок6    |3        |7        |5        |2        |5


У товаров есть некие состава (fild1 ... fild5).
Эти свойства (их значения - целые числа) динамически. 
Чем больше число, тем больше подходит свойство к этому товару.

Например, у товара id=3 главным свойством является fild4 (т.к. имеет максимальное значение среди других свойств этого товара), 
а два второстепенных свойства fild2, fild5. 

Существует ли запрос (или группа запросов), которая сможет вывести сначала все товары, где главное свойство fild4, а затем товары, где fild4 является одним из двух второстепенных свойств?

Спасибо.

PM MAIL   Вверх
Akina
Дата 15.3.2012, 12:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 454



Введите дополнительное поле, обновляемое из триггера и содержащее максимальное среди свойств этого товара значение.
После чего отберите товары, где главное свойство fild4, сравнением этого поля с полем fild4, а товары, где fild4 является одним из двух второстепенных свойств - сравнением поля fild4 с нулём.



--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
Zloxa
Дата 15.3.2012, 12:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 33
Всего: 161



Цитата(Jiffi @  15.3.2012,  11:45 Найти цитируемый пост)
где главное свойство fild4, 

where field4 = greatest(field1,field2,field3,field4,field5)
Цитата(Jiffi @  15.3.2012,  11:45 Найти цитируемый пост)
где fild4 является одним из двух второстепенных свойств?

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

Добавлено @ 12:26
Цитата(Akina @  15.3.2012,  13:23 Найти цитируемый пост)
одним из двух второстепенных свойств - сравнением поля fild4 с нулём.

Я так понял "одно из двух второстепенных свойств" = "имеет ранг 2,3"
идеи сравнения с нулем - не понял

Добавлено @ 12:29
т.е. как бы второй ранг еще можно получить как - то так

Код

field4= greatest(coalesce(nullif(field1,greatest(field1,field2,field3,field4,field5)),0)
                ,coalesce(nullif(field2,greatest(field1,field2,field3,field4,field5)),0)
                ,coalesce(nullif(field3,greatest(field1,field2,field3,field4,field5)),0)
                ,coalesce(nullif(field4,greatest(field1,field2,field3,field4,field5)),0)
                ,coalesce(nullif(field5,greatest(field1,field2,field3,field4,field5)),0)
                )


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

Это сообщение отредактировал(а) Zloxa - 15.3.2012, 12:34


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MySQL | Следующая тема »


 




[ Время генерации скрипта: 0.0877 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.