AGB  ·  Datenschutz  ·  Impressum  







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

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
 
#1

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

  Alt 30. Okt 2019, 17:05
Datenbank: Sqlite • Version: 3.x • Zugriff über: FireDAC
Folgendes Minimalbeispiel:

Man werfe auf sein Form1 folgendes:
  • TFDPhysSQLiteDriverLink
  • TFDGUIxWaitCursor
  • TFDConnection

Setze für FDConnection.Params.Database einen Dateipfad seiner Wahl
sowie das Event "AfterConnect":

und nutze folgenden Code:

Delphi-Quellcode:
procedure TForm1.FormCreate(Sender: TObject);
begin
   FDConnection1.Connected := True;
end;

procedure TForm1.Button1Click(Sender: TObject);
const
   donger = '( ͡° ͜ʖ ͡°)';
   statement = 'INSERT INTO [myTable] VALUES(:id, :someText)';
   fieldTypes: TArray<TFieldType> = [TFieldType.ftString, TFieldType.ftWideString];
begin
   FDConnection1.ExecSQL(statement, ['Günther', donger]);
end;

procedure TForm1.handleAfterConnect(Sender: TObject);
const
   buildScript =
      'CREATE TABLE [myTable]('+
      ' [id] TEXT PRIMARY KEY NOT NULL UNIQUE ON CONFLICT REPLACE, '+
      ' [someText] TEXT);';
begin
   // FDConnection1.ExecSQL(buildScript); // nur beim ersten mal wenn die Datei noch nicht existiert
end;

Im Button1.Click füge ich über TFDConnection.ExecSQL(..) Werte in die Tabelle ein. "Günther" ist noch ok, "( ͡° ͜ʖ ͡°)" hingegen nicht mehr - Hier kommen nur noch die Klammern richtig in der Datenbank an.

Grund ist dass FireDAC, soweit nichts explitit angegeben ist, für die Parameter wohl einen FeldTyp "String" statt "WideString" annimmt. Kann ich das irgendwo steuern? Was für einen Sinn macht es noch Ansi-Strings zu nehmen?

Ich habe bei der TFDConnection die Einstellung Params.StringFormat gefunden und auf Unicode gestellt, aber das macht keinen Unterschied...
  Mit Zitat antworten Zitat
 

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 11:17 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