AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken FB2, IBDAC, Select mit IN preparen ?
Thema durchsuchen
Ansicht
Themen-Optionen

FB2, IBDAC, Select mit IN preparen ?

Ein Thema von hoika · begonnen am 22. Nov 2013 · letzter Beitrag vom 23. Nov 2013
Antwort Antwort
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.275 Beiträge
 
Delphi 10.4 Sydney
 
#1

FB2, IBDAC, Select mit IN preparen ?

  Alt 22. Nov 2013, 15:26
Datenbank: FB • Version: 2 • Zugriff über: IBDAC
Hallo #,

folgende Query soll optimiert werden.

Select Id,Name From IdName
Where Id In(:Ids)

Das Ids steht für beliebige Werte.

Problem:
Das Prepare klappt, das ParamByName bringt keine Fehlermeldung,
beim Open sehe ich im SQL-Monitor aber, dass er das :Ids nicht ersetzt hat.

Ein Bug von IBDAC (Version 3.10.10) ?
Heiko
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: FB2, IBDAC, Select mit IN preparen ?

  Alt 22. Nov 2013, 15:56
Nein, FB unterstützt dass in dieser Form nicht.
Markus Kinzler
  Mit Zitat antworten Zitat
Mikkey

Registriert seit: 5. Aug 2013
265 Beiträge
 
#3

AW: FB2, IBDAC, Select mit IN preparen ?

  Alt 22. Nov 2013, 16:15
Nein, FB unterstützt dass in dieser Form nicht.
Ich glaube auch nicht, dass das irgendein DBMS unterstützt, wie sollte denn auch der Wert, der da als Parameter gesetzt wird, interpretiert werden?

mit

Code:
... IN (:P1, :P2, :P3 ..., :Pn)
würde ein Schuh draus, das müsste eigentlich immer funktionieren.
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.275 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: FB2, IBDAC, Select mit IN preparen ?

  Alt 22. Nov 2013, 16:15
Hallo,

und warum klappt es unter IBExpert ?


Heiko
Heiko
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: FB2, IBDAC, Select mit IN preparen ?

  Alt 22. Nov 2013, 16:21
Möglicherweise ersetzt dann IBExpert den Parameter durch den Wert/Inhalt.

In diesem Fall könnte die Makrofunktion von IBDAC helfen
Markus Kinzler
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.275 Beiträge
 
Delphi 10.4 Sydney
 
#6

AW: FB2, IBDAC, Select mit IN preparen ?

  Alt 22. Nov 2013, 17:03
Hallo,

ich schaue die mir mal an.
Zur Not baue ich halt ein paar OR's.


Heiko
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von FBrust
FBrust

Registriert seit: 4. Okt 2002
Ort: Saarbrücken
654 Beiträge
 
Delphi 10.4 Sydney
 
#7

AW: FB2, IBDAC, Select mit IN preparen ?

  Alt 22. Nov 2013, 18:34
Hallo,

wahrscheinlich funktioniert das IN-Statement nicht in Kombination mit Parametern.

Hast Du mal versucht, den SQL-String zuerst zu erstellen und dann der Query zuzuweisen?

Also ungefähr so:

Delphi-Quellcode:
SQL := 'Select Id,Name From IdName Where Id in (' + IntToStr(ID1) + ',' + InttoStr(ID2) + ....usw uaf + ')';

query.SQL.Text := SQL;
Ist jetzt nicht getestet, ich denke schon, dass Firebird mit dem IN-Statement klar kommt, aber die Formatierung ist dann anders.

Gruß
Frank
"Ich habe Dinge gesehen, die ihr Menschen niemals glauben würdet. Gigantische Schiffe, die brannten, draußen vor der Schulter des Orion" - Roy Batty
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.275 Beiträge
 
Delphi 10.4 Sydney
 
#8

AW: FB2, IBDAC, Select mit IN preparen ?

  Alt 23. Nov 2013, 09:12
Hallo,

das hattest du falsch verstanden.
Das IN klappt ja, nur wird es in einer Schleife benutzt
(Es sind ~1000 IDs, FB macht da irgendwann schlapp,
weil das SQL-Statement zu groß wird).


Heiko
Heiko
  Mit Zitat antworten Zitat
tsteinmaurer

Registriert seit: 8. Sep 2008
Ort: Linz, Österreich
530 Beiträge
 
#9

AW: FB2, IBDAC, Select mit IN preparen ?

  Alt 23. Nov 2013, 11:25
Hallo,

Firebird hat ein ~ 64K Limit eines SQL Statements bzw. auch ein Limit von ca. 1499 Elementen in einem IN Operator. D.h. irgendein Limit könnte hier bei dir aufschlagen.

Du könntest über eine GTT gehen. Dort deine IDs insertieren und darauf das SQL mit dem IN oder einem JOIN darauf los lassen.

T.
  Mit Zitat antworten Zitat
Antwort Antwort


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 02:30 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