AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi [Zeos] Probleme mit Parametern bei SQL - Statement
Thema durchsuchen
Ansicht
Themen-Optionen

[Zeos] Probleme mit Parametern bei SQL - Statement

Ein Thema von Mithrandir · begonnen am 27. Apr 2009 · letzter Beitrag vom 27. Apr 2009
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Mithrandir
Mithrandir
(CodeLib-Manager)

Registriert seit: 27. Nov 2008
Ort: Delmenhorst
2.379 Beiträge
 
#1

[Zeos] Probleme mit Parametern bei SQL - Statement

  Alt 27. Apr 2009, 10:44
Datenbank: Firebird Embedded • Version: 2.1.2 • Zugriff über: ZEOS 6.6.4
Hi ihr,

Um für meinen Routenplaner möglichst schnell auf die entsprechenden Daten zugreifen zu können, nutze ich eine SQL-Datenbank.

Dabei dachte ich mir, ich könnte mit einem einfachen INSERT - Statement die Daten in die Datenbank eintragen. Allerdings funktioniert das nicht wie gedacht.

So werden die Daten in die Datenbank geschrieben:

Delphi-Quellcode:
procedure TORPDataBase.WriteNodeToDB(Node: TORPNode);
begin
  fQuery := TZQuery.Create(nil);
  try
    DecimalSeparator := '.';
    with fQuery do
    begin
      Connection := fConnection;
      ParamCheck := true;
      SQL.Add('INSERT INTO `NODES` (TILE, TIMESTAMP, TAGS, VISIBLE, USER_ID, LONGITUDE, LATITUDE, ID) VALUES (:tile, :timestamp, :tags, :visible, :userid, :lon, :lat, :id)');
      ParamByName('tile').AsInteger := 0;
      ParamByName('timestamp').AsDateTime := Now();
      ParamByName('tags').AsString := '';
      ParamByName('visible').AsInteger := 1;
      ParamByName('userid').AsInteger := 0;
      ParamByName('lon').AsFloat := StrToFloat(Node.Lon);
      ParamByName('lat').AsFloat := StrToFloat(Node.Lat);
      ParamByName('id').AsInteger := StrToInt(Node.ID);
      ExecSQL;
    end;
  finally
    fQuery.Free;
  end;
end;
So wird die Verbindung aufgebaut:

Delphi-Quellcode:
function TORPDatabase.Connect(DBUser, DBPassword, DBHostName: string): boolean;
begin
  with fConnection do
  begin
    Protocol := 'firebird-2.0';
    ReadOnly := false;
    User := DBUser;
    Password := Password;
    Database := fCompleteDBPath;
    HostName := DBHostName;
    if not FileExists(fCompleteDBPath) then
      CreateEmptyDB;
    Connect;
    Result := Connected;
  end;
end;
Es scheint, als würden in dem Code oben die Parameter nicht verarbeitet werden. Zumindest sieht der resultierende SQL - String so aus:

INSERT INTO `NODES` (TILE, TIMESTAMP, TAGS, VISIBLE, USER_ID, LONGITUDE, LATITUDE, ID) VALUES (?, ?, ?, ?, ?, ?, ?, ?) Sieht jemand, was ich falsch mache?
米斯蘭迪爾
"In einer Zeit universellen Betruges wird das Aussprechen der Wahrheit zu einem revolutionären Akt." -- 1984, George Orwell
  Mit Zitat antworten Zitat
Benutzerbild von mirage228
mirage228

Registriert seit: 23. Mär 2003
Ort: Münster
3.750 Beiträge
 
Delphi 2010 Professional
 
#2

Re: [Zeos] Probleme mit Parametern bei SQL - Statement

  Alt 27. Apr 2009, 10:46
Edit: Vielleicht hilft ein zusätzlicher "Prepare()"-Aufruf.

Viele Grüße
David F.

May the source be with you, stranger.
PHP Inspection Unit (Delphi-Unit zum Analysieren von PHP Code)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: [Zeos] Probleme mit Parametern bei SQL - Statement

  Alt 27. Apr 2009, 10:49
Parameter werden serverseitig angewendet. Deshalb verändern sie den Abfragestring nicht.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Mithrandir
Mithrandir
(CodeLib-Manager)

Registriert seit: 27. Nov 2008
Ort: Delmenhorst
2.379 Beiträge
 
#4

Re: [Zeos] Probleme mit Parametern bei SQL - Statement

  Alt 27. Apr 2009, 10:50
Zitat von mirage228:
Edit: Vielleicht hilft ein zusätzlicher "Prepare()"-Aufruf.
Edit 2: Sicher, dass es SQL.Add() sein muss? Vorherige Einträge bleiben so in der StringList, ggf. solltest Du SQL.Text := ... verwenden.

Viele Grüße
Hi,

Prepare() kennt ZEOS irgendwie nicht..

An .Add liegt es vermutlich nicht, weil ich das Objekt ja frisch erstellt habe. Ich habe trotzdem mal auf .Text umgestellt. Das Problem löst es leider nicht..
米斯蘭迪爾
"In einer Zeit universellen Betruges wird das Aussprechen der Wahrheit zu einem revolutionären Akt." -- 1984, George Orwell
  Mit Zitat antworten Zitat
Benutzerbild von mirage228
mirage228

Registriert seit: 23. Mär 2003
Ort: Münster
3.750 Beiträge
 
Delphi 2010 Professional
 
#5

Re: [Zeos] Probleme mit Parametern bei SQL - Statement

  Alt 27. Apr 2009, 10:51
Moin,

Achso, ja, ich vergaß, ZEOS macht ein "Prepare()" immer nur intern, für den Nutzer gibt es eine solche Funktion nicht...
Also zur Darstellung hat mkinzler ja schon was geschrieben ... die Frage ist nun, ob der Datensatz nun korrekt in der DB landet oder nicht?
David F.

May the source be with you, stranger.
PHP Inspection Unit (Delphi-Unit zum Analysieren von PHP Code)
  Mit Zitat antworten Zitat
Benutzerbild von Mithrandir
Mithrandir
(CodeLib-Manager)

Registriert seit: 27. Nov 2008
Ort: Delmenhorst
2.379 Beiträge
 
#6

Re: [Zeos] Probleme mit Parametern bei SQL - Statement

  Alt 27. Apr 2009, 10:52
Hm.. Also, die Fehlermeldung lautet im Wortlaut:

Code:
---------------------------
Benachrichtigung über Debugger-Exception
---------------------------
Im Projekt saxxmltest.exe ist eine Exception der Klasse EZSQLException mit der Meldung 'SQL Error: Dynamic SQL Error SQL error code = -104 Token unknown - line 1, column 13 `. Error Code: -104. Invalid token The SQL: INSERT INTO `NODES` (TILE, TIMESTAMP, TAGS, VISIBLE, USER_ID, LONGITUDE, LATITUDE, ID) VALUES (?, ?, ?, ?, ?, ?, ?, ?); ' aufgetreten.
---------------------------
Anhalten  Fortsetzen  Hilfe  
---------------------------
米斯蘭迪爾
"In einer Zeit universellen Betruges wird das Aussprechen der Wahrheit zu einem revolutionären Akt." -- 1984, George Orwell
  Mit Zitat antworten Zitat
Benutzerbild von mirage228
mirage228

Registriert seit: 23. Mär 2003
Ort: Münster
3.750 Beiträge
 
Delphi 2010 Professional
 
#7

Re: [Zeos] Probleme mit Parametern bei SQL - Statement

  Alt 27. Apr 2009, 10:55
Das Problem scheint zu sein, dass Firebird die ` um `NODES` nicht mag. Lass die mal weg, müsste auch ohne gehen...
David F.

May the source be with you, stranger.
PHP Inspection Unit (Delphi-Unit zum Analysieren von PHP Code)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#8

Re: [Zeos] Probleme mit Parametern bei SQL - Statement

  Alt 27. Apr 2009, 10:55
Ersetze die Hochkommas um `NODES` mit "NODES" oder lass diese ganz weg
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Mithrandir
Mithrandir
(CodeLib-Manager)

Registriert seit: 27. Nov 2008
Ort: Delmenhorst
2.379 Beiträge
 
#9

Re: [Zeos] Probleme mit Parametern bei SQL - Statement

  Alt 27. Apr 2009, 11:02
Das war's.

Ihm gefielen die Hochkommas nicht, bei TIMESTAMP haben sie gefehlt.

Kleine Frage am Rande:

Ich habe mehrere 100.000 Nodes, die ich in die Tabelle einfügen muss. Für jedes fahre ich ein eigenes "INSERT INTO" Statement auf. Dabei habe ich das Gefühl, dass sich die Performance in Grenzen hält. Kann man da noch was machen, bspw. mehrere Zeilen auf einmal einfügen? Oder ist "INSERT INTO" nur auf eine Zeile beschränkt?
米斯蘭迪爾
"In einer Zeit universellen Betruges wird das Aussprechen der Wahrheit zu einem revolutionären Akt." -- 1984, George Orwell
  Mit Zitat antworten Zitat
Benutzerbild von mirage228
mirage228

Registriert seit: 23. Mär 2003
Ort: Münster
3.750 Beiträge
 
Delphi 2010 Professional
 
#10

Re: [Zeos] Probleme mit Parametern bei SQL - Statement

  Alt 27. Apr 2009, 11:09
Das hatte ich auch mal. Es ging wesentlich schneller, als ich
Code:
INSERT INTO ... VALUES (..., ..., ...), (..., ..., ...), ...
also ein großes SQL-Statement mit allen Datensätzen rausgeschickt habe.
David F.

May the source be with you, stranger.
PHP Inspection Unit (Delphi-Unit zum Analysieren von PHP Code)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 19:14 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz