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
Seite 1 von 3  1 23      
idefix2

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

Zeitverhalten einer join Abfrage

  Alt 1. Mai 2015, 13:29
Datenbank: Access • Version: 2002 • Zugriff über: ADO
Ich habe zwei Tabellen, Tabelle A (Primärschlüssel A_Nr) mit 200000 Datensätzen, und eine zweite Tabelle B mit vielleicht 10000 Datensätzen (Primärschlüssel B_Nr), die über einen Fremdschlüssel A.B_Nr mit der Tabelle A verknüpft ist.

Wenn ich folgende Abfrage mache, scheint er zuerst eine Riesen Join-Tabelle für alle Datensätze von A zu machen und dann erst über die where-Klausel den einen, den ich will, herauszugreifen (vermute ich auf Grund des Zeitverhaltens):

Code:
select A.*, B.* from A left join B on A.B_Nr=B.B_Nr where A.A_Nr=1785
wie müsste man die Abfrage formulieren, damit er nur für den einen Datensatz mit A.A_Nr=1785 die gejointe Tabelle aufbaut? Das Ganze ist in einem älteren Projekt noch auf Basis von Access 2002, da scheint der SQL-Optimierer von Access noch nicht besonders effizient zu sein.

Ich muss das mittels Query machen und kann nicht locate oder dgl. verwenden, weil die ganze Programmstruktur danach mit dem Ergebnis einer Query weiterarbeitet.

Geändert von idefix2 ( 1. Mai 2015 um 13:51 Uhr)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Zeitverhalten einer join Abfrage

  Alt 1. Mai 2015, 13:42
Mit etwas (viel) Glück funktioniert

SQL-Code:
select
  A.*, B.*
from
  ( select * from A where A.A_Nr=1785) A
    left join B on A.B_Nr=B.B_Nr;
Markus Kinzler
  Mit Zitat antworten Zitat
idefix2

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

AW: Zeitverhalten einer join Abfrage

  Alt 1. Mai 2015, 13:52
Danke, ich probiers einmal so aus.
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#4

AW: Zeitverhalten einer join Abfrage

  Alt 1. Mai 2015, 13:56
Auf welchen Feldern ist ein Index?
  Mit Zitat antworten Zitat
jobo

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

AW: Zeitverhalten einer join Abfrage

  Alt 1. Mai 2015, 14:52
Und noch die Frage:
Sind die Tabellen nativ in Access oder sind es verlinkte Tabellen, die faktisch auf irgendeinem DB Server liegen?

Falls nativ Access kann man die Variante von mkinzler noch in 2 Separate Access Abfragen splitten, wenn es keinen Erfolg bringt. Innen die Einschränkung auf ein Satz, außen den Join. Irgendwie wird man Access das schon beibringen können.
Falls nicht nativ, sondern linked tables, kenne ich es auch so, dass Access einfach Blödsinn macht (das war aber Access 2000 oder 2003?), weil es offenbar keine brauchbaren Modellinformationen / Statistik findet oder finden will. Dann lieber gleich auch linked queries (pass through)einsetzen.
Gruß, Jo
  Mit Zitat antworten Zitat
idefix2

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

AW: Zeitverhalten einer join Abfrage

  Alt 1. Mai 2015, 15:12
Index natürlich auch auf allen Primärschlüsselfeldern.
Die oben vorgeschlagene Abfrage funktioniert leider nicht, irgend etwas an der Syntax passt Access nicht.
Die Tabellen liegen nativ in Access vor.

und leider kann ich die Abfrage nicht splitten. Das Ganze findet innerhalb eines Programmframeworks statt, dem ich ein SQL Statement übergebe, und das eine Tabelle (in dem Fall mit nur einer Zeile) zurückliefert.

Die Access-Hilfe zu dem Thema ist eine Frechheit:

Syntax
SELECT Feldliste
FROM Tabellenausdruck [IN ExterneDatenbank]

Tabellenausdruck: Ein Ausdruck, der eine oder mehrere Tabellen kennzeichnet, aus denen Daten abgerufen werden. Der Ausdruck kann ein einzelner Tabellenname sein, ein Name einer gespeicherten Abfrage oder ein zusammengesetzter Name, der sich aus einer Verknüpfung (INNER JOIN LEFT JOIN, oder RIGHT JOIN) ergibt.

Wird daraus irgend jemand klug? Wie soll so ein "zusammengesetzter Name" konkret ausschauen? beispiele dazu gibt es in dieser "Hilfe" nicht.

Ein gepeicherte Abfrage könnte ich zur Not verwenden - aber nur sehr ungern, weil wie bekomme ich eine gespeicherte Abfrage automatisiert auf Kundendatenbanken? Das geht vermutlich nicht über ein vom Programm generiertes (SQL)-Statement - und mir ist auch nicht klar, ob und wie ich einer gespeicherten Abfrage Parameter übergeben kann.

Geändert von idefix2 ( 1. Mai 2015 um 15:28 Uhr)
  Mit Zitat antworten Zitat
jobo

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

AW: Zeitverhalten einer join Abfrage

  Alt 1. Mai 2015, 15:25
Dann versuch die Abfrage zu zerteilen wie beschrieben.
Gruß, Jo
  Mit Zitat antworten Zitat
idefix2

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

AW: Zeitverhalten einer join Abfrage

  Alt 1. Mai 2015, 19:20
Das ist leider auch nicht möglich - ich muss einen SQL-String mit einem Select-befehl an das Framework übergeben, das mir dann die Antwort zurückliefert.
Ich hoffe, ich habe jetzt ein Workaround gefunden, muss aber noch schauen, ob das so funktioniert:
Eine Hifstabelle, in der nur eine Zeile mit dem Schlüssel des Datensatzes steht, den ich haben will. Dann mache ich ein left join der Hilfstabelle mit der Tabelle A, und danach erst das left join mit der Tabelle B.
Trotzdem denke ich, dass das irgendwie ohne solche Kunstgriffe gehen müsste.

edit: So funktioniert es und ist im Vergleich zu vorher sehr viel schneller. Interessieren würde mich trotzdem, ob das nicht irgendwie besser zu lösen ist als mit einer extra einspaltigen und einzeiligen Tabelle. Aber Access 2002 ist natürlich nicht ganz die neueste Software...

Geändert von idefix2 ( 1. Mai 2015 um 20:29 Uhr)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Zeitverhalten einer join Abfrage

  Alt 1. Mai 2015, 20:48
Ein richtiges DBMS nehmen
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

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

AW: Zeitverhalten einer join Abfrage

  Alt 2. Mai 2015, 01:36
Ein richtiges DBMS nehmen


Nachdem ich mit 70k Datensätzen und Access als Frontend einen fantastischen Schiffbruch erlitten habe kann ich ,freundlich ausgedrückt nur von Access abraten. Meine ehrliche Meinung ist leider mit den Forenregeln nicht kompatibel.

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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 05:56 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