Einzelnen Beitrag anzeigen

Der schöne Günther

Registriert seit: 6. Mär 2013
6.110 Beiträge
 
Delphi 10 Seattle Enterprise
 
#4

AW: FireDAC: ExecSql(..) übernimmt Parameter als Ansi-Strings

  Alt 30. Okt 2019, 18:08
Ich kenne mich mit Datenbanken nicht aus. Was sind denn Verbindungsparameter? Es ist nur Sqlite. Hier einmal eine komplette Konsolenanwendung:

Delphi-Quellcode:
program Project1;

{$APPTYPE CONSOLE}
{$R *.res}

uses
  System.SysUtils,
  System.IOUtils,
  {$REGION 'FireDAC.*'}
  FireDAC.Comp.Client,
  FireDAC.Phys.SQLite,
  FireDAC.Phys.SQLiteDef,
  FireDAC.Stan.Def,
  FireDAC.Stan.Async
  {$ENDREGION}
;

type
   TTest = class
      class procedure RunBuildScript(Sender: TObject);
      class procedure Test();
      class procedure InsertTestValues(const connection: TFDConnection);
   end;


class procedure TTest.Test();
const
   filePath: String = 'y:\myDatabase.db';
var
   connection:   TFdConnection;
   driverLink:   TFDPhysSQLiteDriverLink;
begin
   connection := nil; driverLink := nil;
   try
      connection := TFDConnection.Create(nil);
      driverLink := TFDPhysSQLiteDriverLink.Create(nil);
      connection.DriverName := 'SQLite';
      (connection.Params as TFDPhysSQLiteConnectionDefParams).StringFormat :=
         TFDSQLiteStringFormat.sfUnicode;

      connection.Params.Database := filePath;
      if not TFile.Exists(filePath) then
         connection.AfterConnect := TTest.RunBuildScript;

      connection.Connected := True;
      InsertTestValues(connection);
   finally
      connection.Free(); driverLink.Free();
   end;
end;

class procedure TTest.RunBuildScript(Sender: TObject);
const
   buildScript =
     'CREATE TABLE [myTable]('+
     ' [id] TEXT PRIMARY KEY NOT NULL UNIQUE ON CONFLICT REPLACE, '+
     ' [someText] TEXT);';
begin
   (Sender as TFDConnection).ExecSQL(buildScript);
end;

class procedure TTest.InsertTestValues(const connection: TFDConnection);
const
   donger = '( ͡° ͜ʖ ͡°)';
   statement = 'INSERT INTO [myTable] VALUES(:id, :someText)';
begin
   connection.ExecSQL(statement, ['Günther', donger]);
end;

begin
   try
      TTest.Test();
   except
      on E: Exception do
         Writeln(E.ClassName, ': ', E.Message);
   end;
   WriteLn(sLineBreak, 'end.'); ReadLn;
end.
Führe ich das aus und schaue mir dann mit einem externen Tool (z.B. Sqlite Expert) was in der Datenbank steht erhalte ich das hier: anmerkung-2019-10-30-190719.png

Setze ich bei ExecSQL(..) explizit die FeldTypen auf Widestring, und nur dann, erhalte ich das hier:
unbenannt.png


Ich bin noch wie der letzte Hinterwäldler auf 10.0 Seattle. Wenn das in einer neueren Version besser ist dann wäre das ja erfreulich.

Geändert von Der schöne Günther (30. Okt 2019 um 18:11 Uhr)
  Mit Zitat antworten Zitat