php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 14.01.2008, 18:34  
leo
Neuer Benutzer
 
Registriert seit: 14.01.2008
Beiträge: 3
leo
Standard performance problem mit join

Hallo, habe folgendes Problem mit einer JOIN Abfrage.

Diese Abfrage:

SELECT belege.renr,belege_artikel.artikel_id,belege_artik el.preis
from belege,belege_artikel
where belege.renr = belege_artikel.renr

bringt das Ergebnis für 18968 Zeilen in (0.09) sek.

Diese Abfrage:

SELECT belege.renr,belege_artikel.artikel_id,belege_artik el.preis
from belege
left join belege_artikel
on belege.renr = belege_artikel.renr

bringt das Ergebnis für 18968 Zeilen in (686.09) sek.

Ich benötige aber unbedingt die Abfareg mit JOIN da ich noch andere Felder auswerten muß.

Wo liegt mein Problem?
leo ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 14.01.2008, 19:27  
Erfahrener Benutzer
 
Registriert seit: 21.05.2008
Beiträge: 9.937
Zergling-new wird schon bald berühmt werden
Standard

Vermutlich ein fehlender Index auf die Spalten, die für die Verknüpfung zuständig sind.
Zergling-new ist offline   Mit Zitat antworten
Alt 14.01.2008, 19:39  
leo
Neuer Benutzer
 
Registriert seit: 14.01.2008
Beiträge: 3
leo
Standard

Ich habe in der Tabelle BELEGE den Index auf renr (rechnungsnummer) gesetzt.

In der Tabelle BELEGE_ARTIKEL den Index auf id, renr (rechnungsnummer) geht nicht, da diese doppelt vorkommen können.
leo ist offline   Mit Zitat antworten
Alt 14.01.2008, 20:17  
Erfahrener Benutzer
 
Registriert seit: 21.05.2008
Beiträge: 9.937
Zergling-new wird schon bald berühmt werden
Standard

Also einen Index solltest du trotzdem setzen können (oder?) - ist ja kein Primärschlüssel.
Zergling-new ist offline   Mit Zitat antworten
Alt 14.01.2008, 22:31  
leo
Neuer Benutzer
 
Registriert seit: 14.01.2008
Beiträge: 3
leo
Standard

DANKE, jetzt habe ich das mit dem INDEX begriffen ..... Läuft alles Bestens.
leo ist offline   Mit Zitat antworten
Antwort


Themen-Optionen
Thema bewerten
Thema bewerten:

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 an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
Frage zu meinem JOIN Statement Benjamin Such Datenbanken 4 12.04.2008 13:20
join über 2 db oder tabellen einer db - performance nixahnung Datenbanken 9 23.02.2008 13:03
[gelöst]LEFT JOIN, DINSTINCT und trotzdem doppelte?!?! stefanjann Datenbanken 10 06.02.2008 11:49
JOIN / LEFT JOIN und Co prinzli Datenbanken 12 05.11.2007 22:15
[Erledigt] wieder ein Problem bei phpmailer und smtp PHP Tipps 2006 24 07.02.2006 01:07
inner join aus db PHP Tipps 2006 8 22.01.2006 01:23
Select Problem Datenbanken 17 16.01.2006 21:54
[Erledigt] Abfrageproblem mit Inner Join Datenbanken 15 29.11.2005 18:17
[Erledigt] LEFT JOIN Query Bildung Datenbanken 6 04.11.2005 15:24
sql-Abfrage inner join - unerklärliches Problem havok Datenbanken 6 17.10.2005 14:32
[Erledigt] Problem mit Backslash Patrick Schwarz PHP Tipps 2005-2 5 26.07.2005 09:54
Join Problem Simon9990 PHP Tipps 2005-2 1 21.07.2005 22:15
Problem mit Where und Join Datenbanken 5 06.07.2005 18:05
[Erledigt] [LEFT JOIN] Verständnis Problem Datenbanken 6 17.06.2005 14:38
[Erledigt] Problem mit JOIN Datenbanken 7 27.08.2004 16:00

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
inner join performanceprobleme

Alle Zeitangaben in WEZ +2. Es ist jetzt 07:07 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum

Creative Commons License
Dieser Inhalt ist unter einer Creative Commons-Lizenz lizenziert.