Subject | RE: Datatypes are not comparable in expression CASE when using TIMESTAMPS |
---|---|
Author | Svein Erling Tysvær |
Post date | 2013-08-08T15:52:12Z |
>I managed to get around it as follows, but I'd say it is a bug:Your description sounds strange, Maya. Not that I'd say it is unreasonable that it barks at the first statement (although Date and Timestamp are so similar that I thought you could use them interchangeably, I've no problems running similar queries to yours, but I hardly ever use Timestamp). If enddate is defined as a TimeStamp and you do cast('Today' as Date), then I'd expect the result to be Date, whereas enddate+1 would be TimeStamp (so the alternatives to reporting an error would either be to truncate the timestamp to a date or expand the date to a timestamp). I'd say that a better way to write your case statement would be to either cast('Today' as TimeStamp), or alternatively cast(p.enddate as Date) (or use CURRENT_TIMESTAMP or CURRENT_DATE, although I think they're slightly different from 'Today'), although as said, I am slightly surprised that you cannot use these field types interchangeably.
>
>What I wanted to do:
>
>case
> when ((p.StartDate <= cast('Today' as date)) and (p.EndDate >= cast('Today' as date))) then
> (cast('Today' as date) + 1)
> else
> p.enddate + 1
> end
>
>What I ended up doing to get around the problem:
>
>case
> when ((p.StartDate <= cast('Today' as date)) and (p.EndDate >= cast('Today' as date))) then
> (cast('Today' as date) + 1)
> --else problem with dates and else section
> when (p.StartDate > cast('Today' as date)) then
> p.enddate + 1
> when (p.EndDate < cast('Today' as date)) then
> p.enddate + 1
> end
What surprises me more is that your first query fails, whereas the second succeeds.
Set