AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Zeitverhalten einer join Abfrage
Thema durchsuchen
Ansicht
Themen-Optionen

Zeitverhalten einer join Abfrage

Ein Thema von idefix2 · begonnen am 1. Mai 2015 · letzter Beitrag vom 4. Mai 2015
Antwort Antwort
idefix2

Registriert seit: 17. Mär 2010
Ort: Wien
1.027 Beiträge
 
RAD-Studio 2009 Pro
 
#1

AW: Zeitverhalten einer join Abfrage

  Alt 4. Mai 2015, 01:22
Das Problem ist ja, dass die Abfrage mit where extrem langsam wird, weil er zuerst die Riesentabelle aufbaut und danach selektiert.
Mit der ON Klausel wird der eine Datensatz gleich beim Join herausselektiert, weil die linke Tabelle nur aus einem Datensatz besteht, und nur dieses kleine Ergebnis wird mit einer Reihe von anderen Tabellen gejoint. Bei einem brauchbaren Query-Optimierer, wie ihn jede halbwegs moderne SQL Datenabnk hat, wäre das ganze Theater nicht nötig.
Ich gehe davon aus, dass eine neuere Access-Version das besser machen würde, aber die Umstellung des ganzen Delphi-5 Projekts auf eine neue Access-Version ist mir zu viel Aufwand.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Zeitverhalten einer join Abfrage

  Alt 4. Mai 2015, 04:56
Wenn ich Umsteigen würde, würde ich gleich ganz von Access weg wechseln
Markus Kinzler
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#3

AW: Zeitverhalten einer join Abfrage

  Alt 4. Mai 2015, 06:46
Wenn man die Sofware rein zufällig etwas strukturiert hätte, könnte man mit moderatem Aufwand umsteigen. Ich vermute, es wird mit ADO gearbeitet, dann bietet sich der MS SQL-Server (Express) an.
  Mit Zitat antworten Zitat
RoadR69

Registriert seit: 7. Nov 2013
17 Beiträge
 
Delphi 10 Seattle Professional
 
#4

AW: Zeitverhalten einer join Abfrage

  Alt 4. Mai 2015, 07:21
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.

select
A.*, B.*
from
( select * from A where A.A_Nr=1785) as A
left join B on A.B_Nr=B.B_Nr;
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#5

AW: Zeitverhalten einer join Abfrage

  Alt 4. Mai 2015, 07:32
Probieren ist immer besser als mutmaßen.

Dann liegt es wohl an etwas Anderem.
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#6

AW: Zeitverhalten einer join Abfrage

  Alt 4. Mai 2015, 07:42
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.
Gruß, Jo
  Mit Zitat antworten Zitat
Benutzerbild von Jasocul
Jasocul

Registriert seit: 22. Sep 2004
Ort: Delmenhorst
1.377 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: Zeitverhalten einer join Abfrage

  Alt 4. Mai 2015, 07:48
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
Peter
  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 06:17 Uhr.
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-2025 by Thomas Breitkreuz