Delphi-PRAXiS
Seite 3 von 3     123   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Zeitverhalten einer join Abfrage (https://www.delphipraxis.net/184932-zeitverhalten-einer-join-abfrage.html)

Jasocul 4. Mai 2015 07:48

AW: Zeitverhalten einer join Abfrage
 
Ich habe hier leider kein Access. Aber kann man das vielleicht so "austricksen":
Code:
select A.*, B.* 
from A
left join B
on A.B_Nr=B.B_Nr
and A.A_Nr=1785

user0815 4. Mai 2015 09:16

AW: Zeitverhalten einer join Abfrage
 
Vielleicht würde es auch helfen die Datenbank einfach zu öffnen & dann zu: "komprimieren und reparieren".
Ist dies nicht möglich dann evtl. per Code: site:delphipraxis.net access datenbank komprimieren

idefix2 4. Mai 2015 11:22

AW: Zeitverhalten einer join Abfrage
 
Zitat:

Zitat von user0815 (Beitrag 1300146)
Vielleicht würde es auch helfen die Datenbank einfach zu öffnen & dann zu: "komprimieren und reparieren".

Leider nein, die Datenbanken werden regelmässig komprimiert und repariert (allein der Aufwand wäre eigentlich schon ein Grund, das Datenbanksystem zu wechseln :-D ). Für neue Projekte verwenden wir ohnedies je nach den Umständen Firebird oder SQLite.

Und auch der Ansatz von Jasocul geht nicht, Access meldet da (beim Ausprobieren der Abfrage direkt in der Access-Entwicklungsumgebung):
Die ON-Anweisung in Ihrer JOIN-Operation ist nicht vollständig oder enthält zu viele Tabellen. Sie sollten ggf. den ON-Ausdruck in einem WHERE-Abschnitt angeben.

Zitat:

Zitat von jobo (Beitrag 1300135)
Zitat:

Zitat von RoadR69 (Beitrag 1300132)
Also ich habe mir mal eine Beispieltabelle in meinem Access angelegt mit jeweils der doppelten Anzahl von Datensätzen ...
Ausführungszeit für die Orginal-Abfrage: sofort da, nicht messbar ...

Auch die 2. Abfrage läuft, welche natürlich etwas besser formuliert ist und mit Einfügen von "AS" (Access will das halt so...) läuft die auch.

Klingt plausibel. Mich hat es gewundert, dass sowas simples nicht geht. Access ist keine Wundersoftware, aber sowas könnten sie können.
Da wäre aber eine wichtige Sache, welche Version ist das?
Dann ist da auch noch dieses ominöse Framwork in das "die Abfrage reingeht". Vielleicht ist das der Übeltäter.

Es hängen an der Abfrage noch ein paar andere Joins mit grossen Tabellen dran, das dürfte es herunterbremsen.
Und das Framework ist nicht schuld, ich habe es im Debugger verfolgt, die Zeit vergeht beim Open der Query. Ich vermute auch, dass neuere Access Versionen das besser handhaben werden, aber die Anwendung ist mit Delphi5 für Access 2002 entwickelt und ich kann mich erinnern, dass auch der Umstieg von Access 97 auf Access 2002 damals mit einigen Troubles verbunden war, das will ich jetzt nicht riskieren (auch wenn es vielleicht gar kein grosser Aufwand wäre, aber das weiss man im voraus nicht)

Jetzt pfeif ich drauf, mit der Hilfstabelle ist das Zeitproblem für fast alle Fälle gelöst, bei einer speziellen Query geht das zwar auch nicht, aber die wird ohnehin kaum verwendet, die braucht eben auch weiterhin länger.

Nachdem ich schon unter ziemlichen Zeitdruck stehe, spiele ich mich jetzt da nicht weiter. Danke jedenfalls für alle Inputs.

edit: ich sehe gerade
Zitat:

Einfügen von "AS" (Access will das halt so...)
Das probier ich noch aus :)

edit2: So Funktioniert es! :thumb:

p80286 4. Mai 2015 11:43

AW: Zeitverhalten einer join Abfrage
 
Manchmal hat es geholfen, die vorhandene Abfrage zu löschen, und ganz neu aufzubauen/einzugeben. Das ist zwar kurz vor Voodoo aber es hat ja auch niemand behauptet daß die Access-Programmierer nicht in der Karibik sitzen.
U.u. ist Pass-through auch hilfreich.

Gruß
K-H


Alle Zeitangaben in WEZ +1. Es ist jetzt 01:19 Uhr.
Seite 3 von 3     123   

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