AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Abfrage

Ein Thema von Jick · begonnen am 10. Mai 2014 · letzter Beitrag vom 13. Mai 2014
Antwort Antwort
Jick

Registriert seit: 12. Jun 2011
26 Beiträge
 
Delphi XE Starter
 
#1

Abfrage

  Alt 10. Mai 2014, 23:00
Datenbank: Firebird • Version: 2,5 • Zugriff über: Zeoslib
Hallo,

ich komme bei einer Select Abfrage nicht weiter, ich habe 2 Tabellen.

Kunde mit

KNDID
FIRMA

ANFRAGEN mit

ANFRAGENR
KNDID
KND2ID

Select KUNDE.FIRMA AS KUNDE, KUNDE.FIRMA AS LIEFERANT From Kunde,Anfragen
where Kunde.KNDID = Anfragen.KNDID and Kunde.KNDID = Anfragen.KND2ID

Wenn ich das so mache bekomme ich nur Ergebnisse wo KNDID = KND2ID ist, bei unterschiedlichen Einträgen geht es nicht.
Wie sieht die SQL-Abfrage aus wenn ich alle Anfragen mit FIRMA von KNDID und FIRMA von KND2ID haben will ?

Grüße
Michael
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.599 Beiträge
 
Delphi 12 Athens
 
#2

AW: Abfrage

  Alt 10. Mai 2014, 23:10
Delphi-Quellcode:
Select a*,
b.FIRMA AS KUNDE,
c.FIRMA AS LIEFERANT
From Anfragen a
LEFT JOIN Kunde b ON a.KNDID = b.KNDID
LEFT JOIN Kunde c ON a.KND2ID = c.KNDID
Der LEFT JOIN sorgt dafür, daß auch Einträge gefunden werden, bei denen keine KNDID oder KND2ID angegeben ist.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

AW: Abfrage

  Alt 10. Mai 2014, 23:14
So
SQL-Code:
select
  kund.Firma as Kund_Firma
  lief.Firma as Lief_Firma
from
  Anfragen anfr
join
  kunde kund on kund.kndid = anfr.kndid
join
  kunde lief on lief.kndid = anfr.knd2id
und dann sieht es auch noch lesbar aus

Kann es sein, dass deine Tabelle "kunde" irgendwie den falschen Namen hat, wenn da Kunden und Lieferanten enthalten sind
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)

Geändert von Sir Rufo (10. Mai 2014 um 23:16 Uhr)
  Mit Zitat antworten Zitat
Jick

Registriert seit: 12. Jun 2011
26 Beiträge
 
Delphi XE Starter
 
#4

AW: Abfrage

  Alt 10. Mai 2014, 23:21
Hallo,

danke euch das werde ich sofort testen.

@Sir Rufo

das mit Kunde und Lieferant ist so gewollt

Grüße
Michael
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#5

AW: Abfrage

  Alt 10. Mai 2014, 23:25
@Sir Rufo

das mit Kunde und Lieferant ist so gewollt
Das ist ja auch legitim, die in einer Tabelle zu halten, nur würde ich diese Tabelle niemals "KUNDE" nennen
(nein, auch nicht "KUNDEN")
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#6

AW: Abfrage

  Alt 11. Mai 2014, 10:55
nur würde ich diese Tabelle niemals "KUNDE" nennen
Sondern?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Abfrage

  Alt 11. Mai 2014, 11:01
Geschaeftspartner, Personenkonten, KundLief, DebKred, ...
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 16. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#8

AW: Abfrage

  Alt 10. Mai 2014, 23:18
Man könnte zwei Unterabfragen verwenden:
SQL-Code:
Select (select KUNDE.FIRMA from Kunde where Kunde.KNDID=Anfragen.KNDID) AS KUNDE,
       (select KUNDE.FIRMA from Kunde where Kunde.KNDID=Anfragen.KND2ID) AS LIEFERANT
From Anfragen
oder man verkettet die beiden Anfragen mit einer Union, was flexibler ist:
SQL-Code:
Select Anfragen.Anfragenr, KUNDE.FIRMA From Kunde, Kunde.KNDID inner join Anfragen on Kunde.KNDID = Anfragen.KNDID
UNION ALL
Select Anfragen.Anfragenr, KUNDE.FIRMA From Kunde, Kunde.KNDID inner join Anfragen on Kunde.KNDID = Anfragen.KND2ID
ORDER BY Anfragen.Anfragenr
fork me on Github
  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 23:44 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 by Thomas Breitkreuz