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 :: Разбиение проектов на группы с учетом валюты

 PHP.SU

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


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

> Без описания
jonston
Отправлено: 28 Апреля, 2020 - 04:08:45
Post Id



Посетитель


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


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




Доброго времени суток.Есть такая задача.Есть таблица проектов с колонками id, name, currency, budget.Колонки budget и currency это цена заказа и валюта.Необходимо выбрать группы до 1000 и свыше 1000 гривен (UAH) с учетом валюты.Валюта либо RUB либо UAH.У меня получился вот такой запрос, но подозреваю, что можно оптимизировать.
CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. SELECT
  3.           (SELECT COUNT(*) FROM projects WHERE IF(currency = 'RUB', budget / 2.8, budget) <= 1000) AS g1,
  4.           (SELECT COUNT(*) FROM projects WHERE IF(currency = 'RUB', budget / 2.8, budget) > 1000) AS g2,
  5.           FROM projects
  6.  

Есть идеи?


-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
Мелкий Супермодератор
Отправлено: 28 Апреля, 2020 - 10:42:48
Post Id



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


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


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




Если предположить что основное условие у вас записано верно...

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT sum(IF(currency = 'RUB', budget / 2.8, budget) <= 1000),
  2. sum(IF(currency = 'RUB', budget / 2.8, budget) > 1000)
  3. FROM projects


-----
PostgreSQL DBA
 
 Top
jonston
Отправлено: 28 Апреля, 2020 - 13:58:29
Post Id



Посетитель


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


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




Мелкий пишет:
Если предположить что основное условие у вас записано верно...

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT sum(IF(currency = 'RUB', budget / 2.8, budget) <= 1000),
  2. sum(IF(currency = 'RUB', budget / 2.8, budget) > 1000)
  3. FROM projects


А если групп может быть больше и могут быть еще дополнительные запросы типа > 500 но < 1000?И как оно считает если бюджет IS NULL?

(Отредактировано автором: 28 Апреля, 2020 - 14:36:55)



-----
$i = 0;
$i = $i++ + ++$i; ?
 
 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