AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi FireDAC: ExecSql(..) übernimmt Parameter als Ansi-Strings
Thema durchsuchen
Ansicht
Themen-Optionen

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

Ein Thema von Der schöne Günther · begonnen am 30. Okt 2019 · letzter Beitrag vom 30. Okt 2019
 
Der schöne Günther

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

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

  Alt 30. Okt 2019, 19: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 19:11 Uhr)
  Mit Zitat antworten Zitat
 


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 13:37 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz