mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-23 04:43:03 +01:00
Fixed problem with 'NOW' conversion to time/timestamp with/without time zones.
Problem reported by Vlad. Tracker unavailable to create ticket.
This commit is contained in:
parent
583c0d9ae4
commit
f385937ad8
@ -683,18 +683,31 @@ void CVT_string_to_datetime(const dsc* desc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// fetch the current datetime
|
// fetch the current datetime
|
||||||
*(ISC_TIMESTAMP*) date = Firebird::TimeStamp::getCurrentTimeStamp().value();
|
*date = TimeZoneUtil::getCurrentGmtTimeStamp();
|
||||||
|
|
||||||
if (expect_type == expect_sql_time_tz || expect_type == expect_timestamp_tz)
|
|
||||||
date->time_zone = cb->getSessionTimeZone();
|
date->time_zone = cb->getSessionTimeZone();
|
||||||
|
|
||||||
if (strcmp(temp, NOW) == 0)
|
switch (expect_type)
|
||||||
{
|
{
|
||||||
if (expect_type == expect_sql_time_tz || expect_type == expect_timestamp_tz)
|
case expect_sql_time_tz:
|
||||||
TimeZoneUtil::localTimeStampToUtc(*date);
|
date->utc_timestamp.timestamp_time =
|
||||||
return;
|
TimeZoneUtil::timeStampTzToTimeTz(*date).utc_time;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case expect_sql_date:
|
||||||
|
case expect_sql_time:
|
||||||
|
case expect_timestamp:
|
||||||
|
// Not really UTC.
|
||||||
|
date->utc_timestamp = TimeZoneUtil::timeStampTzToTimeStamp(
|
||||||
|
*date, cb->getSessionTimeZone());
|
||||||
|
break;
|
||||||
|
|
||||||
|
case expect_timestamp_tz:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (strcmp(temp, NOW) == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
if (expect_type == expect_sql_time || expect_type == expect_sql_time_tz)
|
if (expect_type == expect_sql_time || expect_type == expect_sql_time_tz)
|
||||||
{
|
{
|
||||||
CVT_conversion_error(desc, cb->err);
|
CVT_conversion_error(desc, cb->err);
|
||||||
@ -703,21 +716,18 @@ void CVT_string_to_datetime(const dsc* desc,
|
|||||||
|
|
||||||
date->utc_timestamp.timestamp_time = 0;
|
date->utc_timestamp.timestamp_time = 0;
|
||||||
|
|
||||||
if (expect_type == expect_sql_time_tz || expect_type == expect_timestamp_tz)
|
|
||||||
TimeZoneUtil::localTimeStampToUtc(*date);
|
|
||||||
|
|
||||||
if (strcmp(temp, TODAY) == 0)
|
if (strcmp(temp, TODAY) == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (strcmp(temp, TOMORROW) == 0)
|
if (strcmp(temp, TOMORROW) == 0)
|
||||||
{
|
{
|
||||||
date->utc_timestamp.timestamp_date++;
|
++date->utc_timestamp.timestamp_date;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strcmp(temp, YESTERDAY) == 0)
|
if (strcmp(temp, YESTERDAY) == 0)
|
||||||
{
|
{
|
||||||
date->utc_timestamp.timestamp_date--;
|
--date->utc_timestamp.timestamp_date;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user