mirror of
https://github.com/postgres/postgres.git
synced 2025-06-16 06:01:02 +03:00
interval: round values when spilling to months
Previously spilled units greater than months were truncated to months. Also document the spill behavior. Reported-by: Bryn Llewelly Discussion: https://postgr.es/m/BDAE4B56-3337-45A2-AC8A-30593849D6C0@yugabyte.com Backpatch-through: master
This commit is contained in:
@ -155,7 +155,7 @@ DecodeISO8601Interval(char *str,
|
||||
{
|
||||
case 'Y':
|
||||
tm->tm_year += val;
|
||||
tm->tm_mon += (fval * MONTHS_PER_YEAR);
|
||||
tm->tm_mon += rint(fval * MONTHS_PER_YEAR);
|
||||
break;
|
||||
case 'M':
|
||||
tm->tm_mon += val;
|
||||
@ -191,7 +191,7 @@ DecodeISO8601Interval(char *str,
|
||||
return DTERR_BAD_FORMAT;
|
||||
|
||||
tm->tm_year += val;
|
||||
tm->tm_mon += (fval * MONTHS_PER_YEAR);
|
||||
tm->tm_mon += rint(fval * MONTHS_PER_YEAR);
|
||||
if (unit == '\0')
|
||||
return 0;
|
||||
if (unit == 'T')
|
||||
@ -528,29 +528,25 @@ DecodeInterval(char **field, int *ftype, int nf, /* int range, */
|
||||
|
||||
case DTK_YEAR:
|
||||
tm->tm_year += val;
|
||||
if (fval != 0)
|
||||
tm->tm_mon += fval * MONTHS_PER_YEAR;
|
||||
tm->tm_mon += rint(fval * MONTHS_PER_YEAR);
|
||||
tmask = (fmask & DTK_M(YEAR)) ? 0 : DTK_M(YEAR);
|
||||
break;
|
||||
|
||||
case DTK_DECADE:
|
||||
tm->tm_year += val * 10;
|
||||
if (fval != 0)
|
||||
tm->tm_mon += fval * MONTHS_PER_YEAR * 10;
|
||||
tm->tm_mon += rint(fval * MONTHS_PER_YEAR * 10);
|
||||
tmask = (fmask & DTK_M(YEAR)) ? 0 : DTK_M(YEAR);
|
||||
break;
|
||||
|
||||
case DTK_CENTURY:
|
||||
tm->tm_year += val * 100;
|
||||
if (fval != 0)
|
||||
tm->tm_mon += fval * MONTHS_PER_YEAR * 100;
|
||||
tm->tm_mon += rint(fval * MONTHS_PER_YEAR * 100);
|
||||
tmask = (fmask & DTK_M(YEAR)) ? 0 : DTK_M(YEAR);
|
||||
break;
|
||||
|
||||
case DTK_MILLENNIUM:
|
||||
tm->tm_year += val * 1000;
|
||||
if (fval != 0)
|
||||
tm->tm_mon += fval * MONTHS_PER_YEAR * 1000;
|
||||
tm->tm_mon += rint(fval * MONTHS_PER_YEAR * 1000);
|
||||
tmask = (fmask & DTK_M(YEAR)) ? 0 : DTK_M(YEAR);
|
||||
break;
|
||||
|
||||
|
Reference in New Issue
Block a user