AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Feld anderer Tabelle zweimal abfragen
Thema durchsuchen
Ansicht
Themen-Optionen

Feld anderer Tabelle zweimal abfragen

Ein Thema von TheMiller · begonnen am 3. Jan 2009 · letzter Beitrag vom 3. Jan 2009
Antwort Antwort
Benutzerbild von TheMiller
TheMiller

Registriert seit: 19. Mai 2003
Ort: Gründau
2.480 Beiträge
 
Delphi XE7 Architect
 
#1

Feld anderer Tabelle zweimal abfragen

  Alt 3. Jan 2009, 18:14
Datenbank: MySQL • Version: 5 • Zugriff über: ZeosDBO
Hallo Jungs & Mädels,

ich habe eine Benutzertabelle, die unter anderem auch den echten Namen enthält (realname) und eine andere Tabelle, die unter anderem folgende Informationen enthält: Eintrag für [realname], eingetragen von [realname].

Die Tabellen sehen so aus:

Code:
[b]benutzer[/b]

benutzerid | username | realname | status | rang [...]

[b]notizen[/b]

notizid | empfaenger | notiz | eingetragenvon | [...]
Ein Datensatz sieht also so aus:

Code:
benutzer

1 | userA | Max Mustermann | 0 | 1
2 | userB | Jen Jennsen | 0 | 2

notizen

1 | 1 | Ich brauche eine Pause | 2
Einen SQL-Join bekomme ich so hin, dass entweder der Empfänger oder aber derjenige angezeigt wird, der die Notiz hinterlassen hat. Ich bekomme aber beides nicht gleichzeitig hin.

Könnt ihr mir helfen? Danke im Voraus!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Feld anderer Tabelle zweimal abfragen

  Alt 3. Jan 2009, 18:26
In dem du die gleiche Tabelle 2 mal dazu joinst und 2 verschiedene Aliase verwendest
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von TheMiller
TheMiller

Registriert seit: 19. Mai 2003
Ort: Gründau
2.480 Beiträge
 
Delphi XE7 Architect
 
#3

Re: Feld anderer Tabelle zweimal abfragen

  Alt 3. Jan 2009, 19:44
Hallo,

ich habe es jetzt so gemacht, wie du es gesagt hast, aber da kommt trotzdem nicht das richtige Ergebnis raus: Hier mal die SQL

SELECT notizen.*, benutzer.realname AS 'name1', benutzer.realname AS 'name2FROM notizen AS notizen LEFT JOIN benutzer AS benutzer ON (notizen.addedby = benutzer.uid) LEFT JOIN benutzer AS benutzerZwei ON (notizen.empfaenger = benutzer.uid); Doch bei den Ergebnissen bekomme ich beides Mal "Max Mustermann" angezeigt.

Oder habe ich dich falsch verstanden, sodass mein Statement falsch ist?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Feld anderer Tabelle zweimal abfragen

  Alt 3. Jan 2009, 19:50
Es ist gefährlich den Alias wie eine Tabelle zu nennen
SQL-Code:
SELECT
    n.*,
    b1.realname AS 'EmpfaengerName',
    b2.realname AS 'EintragerName
FROM
    notizen n
        LEFT JOIN benutzer b1 ON b1.uid = n.addedby
        LEFT JOIN benutzer b2 ON b2.uid = n.empfaenger;
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von TheMiller
TheMiller

Registriert seit: 19. Mai 2003
Ort: Gründau
2.480 Beiträge
 
Delphi XE7 Architect
 
#5

Re: Feld anderer Tabelle zweimal abfragen

  Alt 3. Jan 2009, 19:59
Tatsache. Das funktioniert!

Diese Schreibweise mit den Alias kannte ich so wirklich noch nicht. Tja, man lernt nie aus.

Vielen Dank
  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 07:37 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