2015-11-10 3 views
0
insert into table (col1, col2, col3, col4) values ('2015-01-01','2014-01-01', NULL, '2013-01-01') 

Я ищу функцию, как это:Как получить минимальную дату нескольких столбцов, исключая нули?

select least_but_no_nulls(col1, col2, col3, col4) from table 

результат: «2013-01-01»

Как я могу получить минимальную дату нескольких столбцов, за исключением аннулирует?

ответ

1

Увы, least() теперь возвращает NULL, если есть аргументы NULL. Вы можете использовать гигантский COALESCE:

select least(coalesce(col1, col2, col3, col3), 
      coalesce(col2, col3, col4, col1), 
      coalesce(col3, col4, col1, col2), 
      coalesce(col4, col1, col2, col3) 
      ) 

Или, вы можете использовать некоторое маловероятное значение в будущем и nullif():

select nullif(least(coalesce(col1, '9999-01-01'), 
        coalesce(col2, '9999-01-01'), 
        coalesce(col3, '9999-01-01'), 
        coalesce(col4, '9999-01-01'), 
        ), '9999-01-01' 
      ) 
Смежные вопросы