Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Temporäre Tabellen durch TFDMemTable ersetzen (https://www.delphipraxis.net/199809-temporaere-tabellen-durch-tfdmemtable-ersetzen.html)

Frickler 28. Feb 2019 09:26

AW: Temporäre Tabellen durch TFDMemTable ersetzen
 
Zitat:

Zitat von haentschman (Beitrag 1426576)
Moin...:P
Zitat:

Es wird eine temporäre Firmen Tabelle erstellt und die selektierten Firmen rein kopiert, damit geht es dann mit einem join auf die Mitarbeitertabelle.
...das verstehe ich nicht. :gruebel: Wenn ich eine Auswahl der Firmen hätte (ID Liste aus dem Grid z.B), da würde ich mir direkt die Daten aus der Datenbank holen...über einen join z.B. Was hat die Temporäre Tabelle für einen Sinn...ein Workaround?

Da wir auch gerade von ADS auf Firebird wechseln, kenne ich die Problematik.

Also... angenommen, Du kannst aus einer Liste (Grid, ListView, etc) Einträge auswählen, zu denen zusätzliche Informationen angezeigt werden sollen. Wenn das nur eine Handvoll Einträge sind, baust Du Dir eine SQL Anweisung a la "select bla from blubb where name in ('name1', 'name2', 'name3', ...)" wobei die "IN ()" Anweisung dynamisch aus den angehakten Listeneinträgen erstellt wird.

Wenn man aber in der Liste dutzende bis hunderte Einträge auswählen kann, wird eine "IN()"-Anweisung irgendwann unglaublich lahm (wenn nicht vorher das Limit für die Länge einer SQL-Anweisung überschritten wird).

Also baust Du Dir eine temporäre Tabelle, trägst dort alle Namen (IDs, Nummern, whatever) ein und JOINst diese gegen die Tabelle, welche die gewünschen Informationen enthält.

Natüüürlich kann man auch eine reguläre Tabelle nehmen, die musst Du aber nachher immer leeren. Eine temporäre Tabelle verschwindet von selbst.

p80286 28. Feb 2019 09:43

AW: Temporäre Tabellen durch TFDMemTable ersetzen
 
Wofür überhaupt eine temporäre Firmentabelle?
Pack die IDs der Firmen in ein Set und gut ist.
SQL-Code:
select ...
from firma join mitarbeiter ....
where
  firma.id in (set der firmenids)
Gruß
K-H

mkinzler 28. Feb 2019 10:38

AW: Temporäre Tabellen durch TFDMemTable ersetzen
 
Zitat:

Natüüürlich kann man auch eine reguläre Tabelle nehmen, die musst Du aber nachher immer leeren. Eine temporäre Tabelle verschwindet von selbst.
GGTs werden auch manuell geleert. Diese werden nur nicht automatisch gedroppt.

peterbelow 28. Feb 2019 12:18

AW: Temporäre Tabellen durch TFDMemTable ersetzen
 
Zitat:

Zitat von p80286 (Beitrag 1426592)
Wofür überhaupt eine temporäre Firmentabelle?
Pack die IDs der Firmen in ein Set und gut ist.
SQL-Code:
select ...
from firma join mitarbeiter ....
where
  firma.id in (set der firmenids)
Gruß
K-H

Die meisten Datenbankserver haben ein Limit für die Zahl der Einträge, die in einer IN-Liste enthalten sein dürfen, und außerdem sind solche Queries aufwendig zu parsen und ziemlich langsam verglichen mit einem Join mit effizient indizierten Tabellen.

p80286 28. Feb 2019 19:46

AW: Temporäre Tabellen durch TFDMemTable ersetzen
 
Das ist ja ein quantitatives Problem.
Die Alternative wäre ein/mehrere Inserts in eine (temporäre) Tabelle. Bei den paar Einträgen (vermute ich) fällt die Indizierung nicht ins Gewicht.

Gruß
K-H


Alle Zeitangaben in WEZ +1. Es ist jetzt 02:22 Uhr.
Seite 2 von 2     12   

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