AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Join innerhalb einer Tabelle
Thema durchsuchen
Ansicht
Themen-Optionen

Join innerhalb einer Tabelle

Ein Thema von DoktorD · begonnen am 17. Aug 2009 · letzter Beitrag vom 17. Aug 2009
Antwort Antwort
DoktorD

Registriert seit: 13. Dez 2005
153 Beiträge
 
#1

Join innerhalb einer Tabelle

  Alt 17. Aug 2009, 11:36
Datenbank: MS SQL • Version: 2000 • Zugriff über: ADO Connection
Servus. Bin noch ein blutiger SQL Anfänger und stoße mittlerweile so an meine Grenzen. Und zwar versuche ich ein InnerJoin innerhalb einer Tabelle zu machen. Bin so vorgegangen wie bei 2 unterschiedlichen Tabelle, aber das funktioniert nicht

Ich habe eine Tabelle mit Messwerten. Die Messwerte sind alle einer PrüfID zugeordnet. Es können mehrere Messwerte zu einer PrüfID existieren.
Ich will nun anhand der Toleranzen (+/- 0,03) eines Messwertes die IDs filtern, die dafür zutreffen. Von diesen übrig gebliebenen IDs will ich dann einen anderen Messwert auslesen und davon dem Mittelwert bilden.

Hier mal ein Bisschen Code (in 2 unterschiedliche Abfragen unterteilt):
SQL-Code:
SELECT dbo.V_JUMO_MEASURE.PRUEFID FROM dbo.V_JUMO_MEASURE
where dbo.V_JUMO_MEASURE.AUFTRAG = '1323259-01AND
      dbo.V_JUMO_MEASURE.MW_NAME = 'Temperatur T1 korrigiertAND
     (dbo.V_JUMO_MEASURE.IST_WERT >= (dbo.V_JUMO_MEASURE.SOLL_WERT - 0.033)) AND
     (dbo.V_JUMO_MEASURE.IST_WERT <= (dbo.V_JUMO_MEASURE.SOLL_WERT + 0.033))

SELECT dbo.V_JUMO_MEASURE.PRUEFID, dbo.V_JUMO_MEASURE.IST_WERT FROM dbo.V_JUMO_MEASURE
where dbo.V_JUMO_MEASURE.AUFTRAG = '1323259-01AND
      dbo.V_JUMO_MEASURE.MW_NAME = 'Widerstand T1 korrigiert'
Kann mir jemand von Euch weiterhelfen? Vielen Dank im Voraus!!!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Join innerhalb einer Tabelle

  Alt 17. Aug 2009, 11:55
Bei Selfjoins benötigst du 2 "Instanzen" einer Tabelle, was du durch Angebae eines Alias erzwingen kannst

SQL-Code:
from
    <Tabelle> t1 join <Tabelle> t2 on t2. ...
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: Join innerhalb einer Tabelle

  Alt 17. Aug 2009, 11:57
Ich weiß nicht, ob ich Dich richtig verstanden habe, aber vielleicht so?
SQL-Code:
SELECT dbo.V_JUMO_MEASURE.PRUEFID, AVG(dbo.V_JUMO_MEASURE.IST_WERT) FROM dbo.V_JUMO_MEASURE
where dbo.V_JUMO_MEASURE.AUFTRAG = '1323259-01AND
      dbo.V_JUMO_MEASURE.MW_NAME = 'Widerstand T1 korrigiertAND dbo.V_JUMO_MEASURE.PRUEFID IN
      (SELECT dbo.V_JUMO_MEASURE.PRUEFID FROM dbo.V_JUMO_MEASURE
       where dbo.V_JUMO_MEASURE.AUFTRAG = '1323259-01AND
             dbo.V_JUMO_MEASURE.MW_NAME = 'Temperatur T1 korrigiertAND
             dbo.V_JUMO_MEASURE.IST_WERT BETWEEN (dbo.V_JUMO_MEASURE.SOLL_WERT - 0.033) AND
             (dbo.V_JUMO_MEASURE.SOLL_WERT + 0.033))
GROUP BY dbo.V_JUMO_MEASURE.PRUEFID
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Jürgen Thomas

Registriert seit: 13. Jul 2006
Ort: Berlin
750 Beiträge
 
#4

Re: Join innerhalb einer Tabelle

  Alt 17. Aug 2009, 12:02
Hallo,

wenn ich deine Frage richtig verstehe, ist die Lösung nicht ein JOIN auf die Tabelle selbst, sondern eher eine Unterabfrage:
Zitat:
Ich will nun anhand der Toleranzen (+/- 0,03) eines Messwertes die IDs filtern, die dafür zutreffen.
Das hast du doch mit dem ersten SELECT-Befehl erreicht.
Zitat:
Von diesen übrig gebliebenen IDs will ich dann einen anderen Messwert auslesen und davon dem Mittelwert bilden.
Also brauchst du als Hauptfrage so etwas:
SQL-Code:
SELECT andererMesswert FROM dbo.V_JUMO_MEASURE
 WHERE PruefID IN ( erster Select );
Und da muss dann noch der Mittelwert eingebaut werden.

Ich hoffe, ich konnte helfen. Jürgen

//Detlef war schneller.
#D mit C# für NET, dazu Firebird
früher: Delphi 5 Pro, Delphi 2005 Pro mit C# (also NET 1.1)
Bitte nicht sauer sein, wenn ich mich bei Delphi-Schreibweisen verhaue; ich bin inzwischen an C# gewöhnt.
  Mit Zitat antworten Zitat
DoktorD

Registriert seit: 13. Dez 2005
153 Beiträge
 
#5

Re: Join innerhalb einer Tabelle

  Alt 17. Aug 2009, 12:11
Stimmt, mit

SQL-Code:
SELECT AVG(dbo.V_JUMO_MEASURE.IST_WERT)
FROM dbo.V_JUMO_MEASURE
WHERE dbo.V_JUMO_MEASURE.PRUEFID IN
(
SELECT dbo.V_JUMO_MEASURE.PRUEFID FROM dbo.V_JUMO_MEASURE
where dbo.V_JUMO_MEASURE.AUFTRAG = '1291626-92AND
      dbo.V_JUMO_MEASURE.MW_NAME = 'Temperatur T1 korrigiertAND
     (dbo.V_JUMO_MEASURE.IST_WERT >= (dbo.V_JUMO_MEASURE.SOLL_WERT - 0.05)) AND
     (dbo.V_JUMO_MEASURE.IST_WERT <= (dbo.V_JUMO_MEASURE.SOLL_WERT + 0.05))
) AND dbo.V_JUMO_MEASURE.MW_NAME = 'Widerstand T1 korrigiert'
funktioniert es.

Aber die Idee von mkienzler ist auch nicht schlecht. Wie kann ich denn einen Alias für eine komplette Tabelle vergeben?
Welche Abfrage müsste denn theoretisch schneller sein?

Vielen Dank
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#6

Re: Join innerhalb einer Tabelle

  Alt 17. Aug 2009, 12:14
Einen SELF JOIN hatten wir eben erst: http://www.delphipraxis.net/internal...t.php?t=163197
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Jürgen Thomas

Registriert seit: 13. Jul 2006
Ort: Berlin
750 Beiträge
 
#7

Re: Join innerhalb einer Tabelle

  Alt 17. Aug 2009, 12:17
Zitat von DoktorD:
Wie kann ich denn einen Alias für eine komplette Tabelle vergeben?
Ein Alias hat nichts mit JOIN oder Unterabfrage oder sonst etwas zu tun; es ist lediglich etwas für Schreibfaule (also für alle Programmierer). Statt überall "dbo.V_JUMO_MEASURE" zu schreiben, kannst du einfach ein Kürzel verwenden; das ist vor allem bei JOINs, also gleichzeitigem Zugriff auf mehrere Tabellen (oder dieselbe Tabelle mehrfach) nützlich.
SQL-Code:
SELECT AVG(meas.IST_WERT)
FROM dbo.V_JUMO_MEASURE meas
WHERE meas.PRUEFID IN ( ... )
Eine Minimalversion für SELF JOIN haben wir gerade unter self join beispiel konstruieren besprochen.

Jürgen

/Detlef war wieder schneller; und der rote Kasten fehlte.
#D mit C# für NET, dazu Firebird
früher: Delphi 5 Pro, Delphi 2005 Pro mit C# (also NET 1.1)
Bitte nicht sauer sein, wenn ich mich bei Delphi-Schreibweisen verhaue; ich bin inzwischen an C# gewöhnt.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Join innerhalb einer Tabelle

  Alt 17. Aug 2009, 12:22
Zitat:
Ein Alias hat nichts mit JOIN oder Unterabfrage oder sonst etwas zu tun; es ist lediglich etwas für Schreibfaule (also für alle Programmierer). Statt überall "dbo.V_JUMO_MEASURE" zu schreiben, kannst du einfach ein Kürzel verwenden;
Jein, bei Self Joins sind sie essentiell, um die verschiedenen "Instanzen" zu erzwingen/unterscheiden
Markus Kinzler
  Mit Zitat antworten Zitat
DoktorD

Registriert seit: 13. Dez 2005
153 Beiträge
 
#9

Re: Join innerhalb einer Tabelle

  Alt 17. Aug 2009, 12:27
Vielen Dank für die Tipps. Damit kann ich auf jeden Fall was anfangen
  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 19:06 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