Einzelnen Beitrag anzeigen

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