AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken max. Länge einer SQL Anweisung?
Thema durchsuchen
Ansicht
Themen-Optionen

max. Länge einer SQL Anweisung?

Ein Thema von bernhard_LA · begonnen am 23. Sep 2014 · letzter Beitrag vom 23. Sep 2014
Antwort Antwort
Seite 2 von 2     12   
Mikkey

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

AW: max. Länge einer SQL Anweisung?

  Alt 23. Sep 2014, 16:49
Bei einer ähnlichen Problematik hat die Query so lange gebraucht, dass der Timeout zugeschlagen hat (auch MSSql).

Nachdem das über eine temporäre Tabelle läuft, ist es etliches schneller. Es handelt sich dabei um getestete 60.000 Ids.

Subquery ging nicht, da es sich um die manuell getätigte Auswahl des Benutzers handelt.
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#12

AW: max. Länge einer SQL Anweisung?

  Alt 23. Sep 2014, 16:55
...Es handelt sich dabei um getestete 60.000 Ids.
...da es sich um die manuell getätigte Auswahl des Benutzers handelt.
So so. Da hat er aber ganz schön geklickt.

Ich weiß schon: Anzeige von 60.000 Möglichkeiten und ein Button 'Alles auswählen', oder?
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#13

AW: max. Länge einer SQL Anweisung?

  Alt 23. Sep 2014, 16:59
...Es handelt sich dabei um getestete 60.000 Ids.
...da es sich um die manuell getätigte Auswahl des Benutzers handelt.
So so. Da hat er aber ganz schön geklickt.

Ich weiß schon: Anzeige von 60.000 Möglichkeiten und ein Button 'Alles auswählen', oder?
für 60.000 mag Dein Sarkasmus angebracht sein, aber Listen mit 200-300 Einträgen sind durchaus möglich (wohlgemerkt nicht durch subquery oder ><=... zu erschlagen)

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
jensw_2000
(Gast)

n/a Beiträge
 
#14

AW: max. Länge einer SQL Anweisung?

  Alt 23. Sep 2014, 21:38
"Zusammengeklickt und lässt sich nicht durch Subquery oder ><=... zu erschlagen" ist immer relativ.

Delphi-Quellcode:
Pseudocode Delphi:

var selectedIDs:TList<derIdTyp> := TList<derIdTyp>.create;
for i:=0 to LangeAuswahlliste.items.count -1 do begin
  if LangeAuswahlliste[i].checked then selectedIDs.add(LangeAuswahlliste[i].id);
end;

// SQL für InnerSelect TEMP Table
SQL_AufbereitungInnerSelect := '';
for id in selectedIDs do begin
  SQL_AufbereitungInnerSelect := SQL_AufbereitungInnerSelect + 'Insert into #SelectedIDs (ID) Values('''+id.ToString+''')' +#13#10;
end;


// SQL Datenabruf
SQL_Datenabruf :=
'BeginTransaction; ' +#13#10+
SQL_AufbereitungInnerSelect +

'SELECT * FROM Tabelle T WHERE T.ID IN (SELECT ID FROM #SelectedIDs)'; +#13#10+
'EndTransaction; ' +#13#10+
Über eine em SQL Server angelegte Stored Procedure kann man das Ganze noch weiter tunen ...
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#15

AW: max. Länge einer SQL Anweisung?

  Alt 23. Sep 2014, 23:10
für 60.000 mag Dein Sarkasmus angebracht sein, aber Listen mit 200-300 Einträgen sind durchaus möglich (wohlgemerkt nicht durch subquery oder ><=... zu erschlagen)
Ich weiß nicht, wieso Du dich auf mich einschießt, aber es ist kein Sarkasmus, einen Beitrag zu kommentieren, der 60.000 verifizierte IDs erwähnt, die durch Benutzereingaben entstanden sind.

Steht ja alles da, ohne Sarkasmus, ohne Witz. Da es eigentlich nicht sein kann, das irgendwer 60.000 Checkboxen anklickt, habe ich ja wohl eine Möglichkeit aufgezeigt, wie so etwas entstehen kann.

Und deine 200-300 Checkboxen, die "wohlgemerkt nicht durch subquery oder ><=... zu erschlagen" sind, würde ich -zumindest wenn ich die Möglichkeit hätte- komplett in die Tonne treten. Und da wäre ich nicht der Einzige. Es mag -wie immer (und bitte gehe nicht schon wieder mit irgendwelchen Sonderfällen darauf ein)- Ausnahmen geben, aber in der Regel wird man diese 200-300 Checkboxen nicht jedesmal komplett neu gewürfelt individuell anklicken (wer hat den die Zeit dazu?), sondern eher in 'Templates', 'Gruppen' o.ä. zusammenfassen. Ich warte übrigens immer noch auf ein konkretes Beispiel, wo das nicht so ist, denn ich lerne immer wieder gerne dazu.

So, nun bist Du wieder dran. Gähn.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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:13 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