瀏覽代碼

* Fix for timestamps very close to a whole day in Firebird

git-svn-id: trunk@43615 -
joost 5 年之前
父節點
當前提交
d8c81744d3
共有 1 個文件被更改,包括 7 次插入0 次删除
  1. 7 0
      packages/fcl-db/src/sqldb/interbase/ibconnection.pp

+ 7 - 0
packages/fcl-db/src/sqldb/interbase/ibconnection.pp

@@ -1442,6 +1442,13 @@ begin
       {$ELSE}
       PISC_TIMESTAMP(CurrBuff)^.timestamp_date := Trunc(PTime) + IBDateOffset;
       PISC_TIMESTAMP(CurrBuff)^.timestamp_time := Round(abs(Frac(PTime)) * IBTimeFractionsPerDay);
+      if PISC_TIMESTAMP(CurrBuff)^.timestamp_time = IBTimeFractionsPerDay then
+        begin
+        // If PTime is for example 0.99999999999999667, the time-portion of the
+        // TDateTime is rounded into a whole day. Firebird does not accept that.
+        inc(PISC_TIMESTAMP(CurrBuff)^.timestamp_date);
+        PISC_TIMESTAMP(CurrBuff)^.timestamp_time := 0;
+        end;
       {$ENDIF}
       end
   else