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

Форум MySQL

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

 

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

вид форума:
Линейный форум Структурный форум

тема: Посчитать сумму если в одном из полей NULL
 
 автор: tAleks   (13.08.2007 в 22:11)   письмо автору
 
 

Как посчитать сумму двух полей средствами MySQL, если в оном из полей может находиться NULL? Ведь люая арифметическая операция с NULL дает NULL. Хотелось бы, чтобы при подстчете, NULL воспримимался, или был преобразован в 0. Но как это сделать?

   
 
 автор: tAleks   (13.08.2007 в 22:21)   письмо автору
 
   для: tAleks   (13.08.2007 в 22:11)
 

По моему я нашел ответ! Еще раз спасибо авторам книги "Самоучитель MySQL 5"!

По моему, тут подойдет функция IFNULL(). Правильно?

   
 
 автор: cheops   (13.08.2007 в 23:01)   письмо автору
 
   для: tAleks   (13.08.2007 в 22:21)
 

Да, или поместить в условие комбинацию функции IF() и конструкции IS NULL (IS NOT NULL).

   
 
 автор: oradev   (13.08.2007 в 23:19)   письмо автору
 
   для: cheops   (13.08.2007 в 23:01)
 


select SUM(IFNULL(col,0)) from table;

   
 
 автор: Trianon   (14.08.2007 в 09:58)   письмо автору
 
   для: tAleks   (13.08.2007 в 22:11)
 


SELECT `fld1`, `fld2`, COALESCE(`fld1`, 0) + `fld2` AS fldsum FROM tbl 

   
Rambler's Top100
вверх

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