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 :: Null Кривит формулу, надо вернуть 0

 PHP.SU

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


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

> Без описания
pantela
Отправлено: 24 Ноября, 2013 - 13:50:19
Post Id



Частый посетитель


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


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




Есть 2 таблицы, в одной список клиентов, в второй записи от куда считается сумма, но бывает иногда что суммы нету у клиента, при этом запрос возращяет NULL, и тогда формула не правильно считает.
CODE (SQL):
скопировать код в буфер обмена
  1. ...
  2. b.auction_pay+b.inside_transport_usa+(SELECT SUM(price) FROM `summa_desc` WHERE `base_id` = b.id)+b.storeg_fee+b.insurance+b.consolidation_fee AS f1
  3. ...

Как тут возрашять не NULL, а 0. т.е. когда в формулу подставляеться NULL, тогда формула кривится.. Огорчение
спс.Ув.
 
 Top
teddy
Отправлено: 24 Ноября, 2013 - 14:02:39
Post Id


Участник


Покинул форум
Сообщений всего: 1462
Дата рег-ции: Апр. 2013  


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




Выполните этот запрос и тогда поле которое нужно по умолчанию примет значение 0
CODE (SQL):
скопировать код в буфер обмена
  1. ALTER TABLE `tablename` ALTER `column` SET DEFAULT 0;

(Добавление)
если конечно же у вас null формируется по дефолту.. тогда вместо null уже будет 0
если будут проблемы уже с существующими значениями тогда просто апдейтом замените все NULL-ы на 0 WHERE `column` IS NULL

(Отредактировано автором: 24 Ноября, 2013 - 14:04:29)

 
 Top
pantela
Отправлено: 24 Ноября, 2013 - 14:05:23
Post Id



Частый посетитель


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


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




Вы не так поняли... А именно то что если записей нету в таблице при запросе SELECT SUM(price) FROM `summa_desc` WHERE `base_id` = b.id откуда и надо взять сумму, тогда NULL возрашяется...
 
 Top
Мелкий Супермодератор
Отправлено: 24 Ноября, 2013 - 14:07:46
Post Id



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


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


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






teddy, здесь NULL появляется из-за sum по 0 строк, поэтому любые DDL не помогут.


-----
PostgreSQL DBA
 
 Top
teddy
Отправлено: 24 Ноября, 2013 - 14:09:52
Post Id


Участник


Покинул форум
Сообщений всего: 1462
Дата рег-ции: Апр. 2013  


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




т.е вам в коде надо как то отрегулировать этот момент? если да то можно проверить на is_null и если оно true, то присвоить выводимой переменной значение 0
PHP:
скопировать код в буфер обмена
  1. $var = null;//допустим что записей нет
  2. if(is_null($var)){
  3.     $var = 0;
  4.     echo $var;
  5. }
 
 Top
pantela
Отправлено: 24 Ноября, 2013 - 14:11:50
Post Id



Частый посетитель


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


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




спс, но тут именно делаю построение алгоритма для view таблицы (там проверку не сделать)

А вот как Мелкий привёл, вот что-то то, вот только по разному пробую и не получается,

(IFNULL(SELECT SUM(price) FROM `summa_desc` WHERE `base_id` = b.id),0)

(SELECT IFNULL(SUM(price) FROM `summa_desc` WHERE `base_id` = b.id),0)
Огорчение

(Отредактировано автором: 24 Ноября, 2013 - 14:12:10)

 
 Top
Мелкий Супермодератор
Отправлено: 24 Ноября, 2013 - 14:35:07
Post Id



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


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


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




CODE (SQL):
скопировать код в буфер обмена
  1. (SELECT IFNULL(SUM(price),0) FROM `summa_desc` WHERE `base_id` = b.id)

ifnull - обычная функция и скобки должны стоять соответственно.


-----
PostgreSQL DBA
 
 Top
pantela
Отправлено: 24 Ноября, 2013 - 15:08:39
Post Id



Частый посетитель


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


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




Ну что сказать... Респект... Подмигивание
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB