Oracle-Datenbankabfrage
Moin alle zusammen.
Beschäftige mich momentan mit Oracle-Abfragen und ich bekomme das iwie mit der INNER JOIN Abfrage nicht hin. SQL ist wesentlich leichter ;)
Also folgendes Problem:
Wir arbeiten hier mit einem ERP-System und ich soll aus der Datenbank die da hinterliegt eine Abfrage machen.
Die Tabellen (3 Stück, alle haben die gleiche Tabellenstruktur, wobei 2 von denen zusammengehören, sprich ich die Daten mit UNION ALL zusammenführe)
In der ersten Abfrage die ich geschrieben habe, steht als erste Spalte die Versandart und als 2 Spalte die KA (sprich Kundenaufträge) die per COUNT gezählt werden.
Select relFb.TEXT1 as Versandart,
count(relFb.ANR) as KA
from relFb
Where TEXT1 IS NOT NULL
AND saint = 10
GROUP BY relFb.TEXT1
Die 2. Abfrage zieht sich die Daten aus 2 verschiedenen Tabellen die ich mit UNION ALL zusammengeführt habe, in denen aber die selbe Tabellenstruktur verwendet wird. Als erste Spalte wieder die Versandart und als 2. Spalte werden hier die EBs auch wieder per COUNT gezählt.
select tt.versandart, count(tt.eb) as EB from (
Select relGb.TEXT1 as Versandart, relGb.belegnrbest as EB
from relGb
Where saint = 210
UNION ALL
Select relxGb.TEXT1 as Versandart, relxGb.belegnrbest as EB
from relxGb
Where saint = 210) tt
GROUP BY tt.versandart
So und jetzt das Problem:
Ich würde das gerne in eine Abfrage haben wollen, in der in der ersten Spalte die Versandart, in der 2.Spalte die KAs und in der 3. Spalte die EB´s jeweils den Versandarten zugeordnet werden.
Ich weiß das ich nach den Versandarten gruppieren muss, aber ich kriege es in ORACLE nicht mit dem JOIN der beiden Tabellen hin.
Ich hofffe Ihr könnt mir bei dem Problem helfen. Falls noch Angaben fehlen sollten kann ich gerne noch weitere Angaben machen.
Ich bedanke mich schoneinmal im Vorraus für eure Hilfe.
Mit freundlichen Grüßen
Tobi
Beschäftige mich momentan mit Oracle-Abfragen und ich bekomme das iwie mit der INNER JOIN Abfrage nicht hin. SQL ist wesentlich leichter ;)
Also folgendes Problem:
Wir arbeiten hier mit einem ERP-System und ich soll aus der Datenbank die da hinterliegt eine Abfrage machen.
Die Tabellen (3 Stück, alle haben die gleiche Tabellenstruktur, wobei 2 von denen zusammengehören, sprich ich die Daten mit UNION ALL zusammenführe)
In der ersten Abfrage die ich geschrieben habe, steht als erste Spalte die Versandart und als 2 Spalte die KA (sprich Kundenaufträge) die per COUNT gezählt werden.
Select relFb.TEXT1 as Versandart,
count(relFb.ANR) as KA
from relFb
Where TEXT1 IS NOT NULL
AND saint = 10
GROUP BY relFb.TEXT1
Die 2. Abfrage zieht sich die Daten aus 2 verschiedenen Tabellen die ich mit UNION ALL zusammengeführt habe, in denen aber die selbe Tabellenstruktur verwendet wird. Als erste Spalte wieder die Versandart und als 2. Spalte werden hier die EBs auch wieder per COUNT gezählt.
select tt.versandart, count(tt.eb) as EB from (
Select relGb.TEXT1 as Versandart, relGb.belegnrbest as EB
from relGb
Where saint = 210
UNION ALL
Select relxGb.TEXT1 as Versandart, relxGb.belegnrbest as EB
from relxGb
Where saint = 210) tt
GROUP BY tt.versandart
So und jetzt das Problem:
Ich würde das gerne in eine Abfrage haben wollen, in der in der ersten Spalte die Versandart, in der 2.Spalte die KAs und in der 3. Spalte die EB´s jeweils den Versandarten zugeordnet werden.
Ich weiß das ich nach den Versandarten gruppieren muss, aber ich kriege es in ORACLE nicht mit dem JOIN der beiden Tabellen hin.
Ich hofffe Ihr könnt mir bei dem Problem helfen. Falls noch Angaben fehlen sollten kann ich gerne noch weitere Angaben machen.
Ich bedanke mich schoneinmal im Vorraus für eure Hilfe.
Mit freundlichen Grüßen
Tobi
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 142033
Url: https://administrator.de/forum/oracle-datenbankabfrage-142033.html
Ausgedruckt am: 21.02.2025 um 11:02 Uhr
5 Kommentare
Neuester Kommentar

Hallo,
in etwa so:
Gruß René
in etwa so:
select tt.versandart, SUM(tt.KA) AS KA, count(tt.eb) as EB from
(
Select relFb.TEXT1 as Versandart, count(relFb.ANR) as KA, sum(0) AS EB
from relFb
Where TEXT1 IS NOT NULL
AND saint = 10
GROUP BY relFb.TEXT1
UNION ALL
Select relGb.TEXT1 as Versandart, 0 AS KA, relGb.belegnrbest as EB
from relGb
Where saint = 210
UNION ALL
Select relxGb.TEXT1 as Versandart, 0 AS KA, relxGb.belegnrbest as EB
from relxGb
Where saint = 210
) tt GROUP BY tt.versandart;
Gruß René

Hallo,
ja ist klar, SUM(0) liefert einen numerischen Wert. Diese korrespondiert nicht mit "belegnrbest", der ist vermutlich "VARCHAR".
Setze für "SUM(0) AS EB" etwas beliebiges ein z.B. "'A' AS EB" oder "TO_CHAR(SUM(0)) AS EB".
Gruß René
ja ist klar, SUM(0) liefert einen numerischen Wert. Diese korrespondiert nicht mit "belegnrbest", der ist vermutlich "VARCHAR".
Setze für "SUM(0) AS EB" etwas beliebiges ein z.B. "'A' AS EB" oder "TO_CHAR(SUM(0)) AS EB".
Gruß René
Moin DerLomi und Bolle 97
a) Wäre es nicht einfacher (zum Copy&Pasten) so:..?
b) muss es im ersten SELECT nicht auch lauten : " AND saint = 210" statt "... AND saint = 10" ??
Grüße
Biber
a) Wäre es nicht einfacher (zum Copy&Pasten) so:..?
Select relFb.TEXT1 as Versandart, count(relFb.ANR) as KA, 0 AS EB
from relFb
Where TEXT1 IS NOT NULL
AND saint = 10
GROUP BY relFb.TEXT1
UNION ALL
-- bisherige Abfrage von oben kopiert, nur das 0 as ka ergänzt
select tt.versandart, 0 as ka, count(tt.eb) as EB from (
Select relGb.TEXT1 as Versandart, relGb.belegnrbest as EB
from relGb
Where saint = 210
UNION ALL
Select relxGb.TEXT1 as Versandart, relxGb.belegnrbest as EB
from relxGb
Where saint = 210) tt
GROUP BY tt.versandart
b) muss es im ersten SELECT nicht auch lauten : " AND saint = 210" statt "... AND saint = 10" ??
Grüße
Biber