sql >> Databasteknik >  >> RDS >> Oracle

ClientDataSet TBCDField avrundning

Jag löste problemet med en annan lösning.

type
   TInternalQuery = class(TQuery)
   protected
      procedure InternalInitFieldDefs; override;
   public
      constructor Create(AOwner: TComponent; const qryGen: TQuery); reintroduce;
   end;

constructor TInternalQuery.Create(AOwner: TComponent; const qryGen: TQuery);
var
   intCont: Integer;
begin
   inherited Create(AOwner);
   Self.DatabaseName := qryGen.DatabaseName;
   Self.UpdateObject := qryGen.UpdateObject;

   Self.SQL.Text := qryGen.SQL.Text;

   for intCont := 0 to Self.ParamCount - 1 do
   begin
     Self.Params[intCont].Value := qryGen.Params[intCont].Value;
   end;  
end;

procedure TInternalQuery.InternalInitFieldDefs;
var
   intCont: Integer;
begin
   inherited InternalInitFieldDefs;
   for intCont := 0 to FieldDefs.Count - 1 do
   begin
      if (FieldDefs[intCont].Size = 0) and (FieldDefs[intCont].DataType = ftBCD) then
      begin
         FieldDefs[intCont].Precision := 64;
         FieldDefs[intCont].Size := 32;
      end;  
   end;  
end;

problemet är ((FieldDefs[intCont].Size =0) och (FieldDefs[intCont].DataType =ftBCD)). när ClientDataSet skapas, trunkeras fältet, eftersom när oracle har en funktion som "SUM(TOTAL)" skapas resultatfältet med storlek 0, så klientdatasetet hanterar fältet som heltalsfält.



  1. DEGREES() Exempel i SQL Server

  2. Oracle 10g - Escape-citat i infoga uttalande

  3. Heroku - ActionView::Mall::Fel (PG::Fel:FEL:kolumn category_products.desc existerar inte

  4. PostgresSQL / pgAdmin4 / dumpserverversion matchar inte