>## 问题 ##
我从这个脚本中得到错误(Postgresql 9.3.2)
(在MS SQL Server中没关系)
SELECT
CASE COALESCE(my_date_field,0)
WHEN 0 THEN 0
ELSE 1 END
AS status
FROM
my_table
Error :COALESCE types timestamp without time zone and integer cannot be matched
Line 2 : CASE COALESCE(my_date_field,0)
## 已解决 ##
SELECT
CASE WHEN my_date_field IS NULL
THEN 0 ELSE 1 END
AS status
FROM
my_table
COALESCE 接受几乎任意数量的参数,但它们应该是相同的数据类型。
我引用了 TSQL 中的 COALESCE 函数
零不是有效日期。令人惊讶的是,它可以在MS SQL中工作。您需要使用合理的日期,或接受NULL
。
CASE COALESCE(my_date_field, DATE '0001-01-01')
查询总体来说有点奇怪。这不是一种令人难以置信的冗长而复杂的IS NULL
写作方式吗?
SELECT
my_date_field IS NULL AS status
FROM
my_table
如果每条注释需要 0 或 1,请使用:
SELECT
CASE WHEN my_date_field IS NULL THEN 1 ELSE 0 END AS status
FROM
my_table