Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

Oracle-Datenbankabfrage

Frage Entwicklung Datenbanken

Mitglied: DerLomi

DerLomi (Level 1) - Jetzt verbinden

04.05.2010 um 07:29 Uhr, 5903 Aufrufe, 5 Kommentare

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
Mitglied: Bolle97
04.05.2010 um 08:57 Uhr
Hallo,

in etwa so:

01.
select tt.versandart, SUM(tt.KA) AS KA, count(tt.eb) as EB from 
02.
03.
   Select relFb.TEXT1 as Versandart, count(relFb.ANR) as KA, sum(0) AS EB 
04.
   from relFb 
05.
   Where TEXT1 IS NOT NULL 
06.
   AND saint = 10 
07.
   GROUP BY relFb.TEXT1 
08.
  UNION ALL 
09.
   Select relGb.TEXT1 as Versandart, 0 AS KA, relGb.belegnrbest as EB  
10.
   from relGb 
11.
   Where saint = 210 
12.
  UNION ALL 
13.
   Select relxGb.TEXT1 as Versandart, 0 AS KA, relxGb.belegnrbest as EB  
14.
   from relxGb 
15.
   Where saint = 210 
16.
 ) tt GROUP BY tt.versandart; 
Gruß René
Bitte warten ..
Mitglied: DerLomi
04.05.2010 um 09:54 Uhr
Ne leider nicht. Bekomme folgende Fehlermeldung

ORA-01790: expression must have same datatype as corresponding expression (markiert wird die deklaration in der 2. select bei sum(0)
Bitte warten ..
Mitglied: Bolle97
04.05.2010 um 10:16 Uhr
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é
Bitte warten ..
Mitglied: Biber
04.05.2010 um 10:26 Uhr
Moin DerLomi und Bolle 97

a) Wäre es nicht einfacher (zum Copy&Pasten) so:..?

01.
 
02.
   Select relFb.TEXT1 as Versandart, count(relFb.ANR) as KA, 0 AS EB 
03.
   from relFb 
04.
   Where TEXT1 IS NOT NULL 
05.
   AND saint = 10 
06.
   GROUP BY relFb.TEXT1 
07.
 
08.
UNION ALL 
09.
-- bisherige Abfrage von oben kopiert, nur das 0 as ka ergänzt 
10.
select tt.versandart, 0 as ka, count(tt.eb) as EB from ( 
11.
Select relGb.TEXT1 as Versandart, relGb.belegnrbest as EB 
12.
from relGb 
13.
Where saint = 210 
14.
UNION ALL 
15.
Select relxGb.TEXT1 as Versandart, relxGb.belegnrbest as EB 
16.
from relxGb 
17.
Where saint = 210) tt 
18.
GROUP BY tt.versandart 
b) muss es im ersten SELECT nicht auch lauten : " AND saint = 210" statt "... AND saint = 10" ??

Grüße
Biber
Bitte warten ..
Mitglied: DerLomi
04.05.2010 um 10:57 Uhr
Jungs...IHR SEIT KLASSE =)

Vielen lieben Dank

Da war mein Lösungsansatz ja garnicht so verkehrt.
Hatte vergessen die dritte Tabelle mit UNION zu verbinden...hatte es mit (+) versucht

Naja so is es dann doch viel einfacher


Vielen Dank nochmal =)

Falls man sich ma irgendwo begegnet habter nen Pils gut ^^

lG Tobi
Bitte warten ..
Ähnliche Inhalte
Datenbanken
Hilfe bei Datenbankabfrage
gelöst Frage von e51bomagDatenbanken11 Kommentare

Hallo liebe Community, hab gerade ein Blackout bzgl. Realisierung einer Abfrage. Folgende Datenbank: noten: nid, loginname, fid, note, type ...

Batch & Shell
Datenbankabfrage Powershell
gelöst Frage von internet2107Batch & Shell3 Kommentare

Ich versuche auf eine Datenbank zuzugreifen, was auch soweit klappt. Jedoch möchte ich gerne alle Tabellen listen, die sich ...

VB for Applications
VBS Scrip - Datenbankabfrage für Netz-Laufwerke spezifizieren
gelöst Frage von Ah3n0bar6usVB for Applications9 Kommentare

Hallo zusammen, Ich habe folgenden Code: Hier werden alle Netz-Lw ausgelesen und ausgegeben. Wie kann ich das jedoch auf ...

Datenbanken
Oracle Procedure Aufruf im Trigger
gelöst Frage von BadFsaadKlDatenbanken3 Kommentare

Moin zusammen, ich habe ein kleines Problem, einen Datenbank Trigger zum laufen zu bekommen, und hoffe Ihr könnt mir ...

Neue Wissensbeiträge
Windows 10

Windows 10 Fall Creators Update - Neue Funktion Hyper-V Standardswitch kann ggf. Fehler bei Proxy Configs verursachen

Erfahrungsbericht von rzlbrnft vor 3 StundenWindows 101 Kommentar

Hallo Kollegen, Da wir die Gefahr lieben, haben wir bei einigen Usern nun mittlerweile das Creators Update drauf. Einige ...

Sicherheit

TLS-Zertifikat und privater Schlüssel von Microsofts Dynamics 365 geleakt

Information von Penny.Cilin vor 5 StundenSicherheit

Microsoft hat versehentlich das TLS-Zertifikat inklusive dem privaten Schlüssel seiner Business-Anwendung Dynamics 365 geleakt. TLS-Zertifikat und privater Schlüssel von ...

Viren und Trojaner

Deaktivierter Keylogger in HP Notebooks entdeckt

Information von bitcoin vor 1 TagViren und Trojaner2 Kommentare

Ein Grund mehr warum man Vorinstallationen der Hersteller immer blank bügeln sollte Der deaktivierte Keylogger findet sich im vorinstallierten ...

Router & Routing

Lets Encrypt kommt auf die FritzBox

Information von bitcoin vor 1 TagRouter & Routing

In der neuesten Labor-Version der FB7490 integriert AVM unter anderem einen Let's Encrypt Client für Zugriffe auf das Webinterface ...

Heiß diskutierte Inhalte
Netzwerkmanagement
Firefox Profieles im Roaming
gelöst Frage von Hendrik2586Netzwerkmanagement17 Kommentare

Hallo liebe Leute. :) Ich hab da ein kleines Problem, welches anscheinend nicht unbekannt ist. Wir nutzen hier in ...

LAN, WAN, Wireless
Brainstorming, einfachste Option 1 getrenntes LAN (mit WAN zugang)
Frage von 132954LAN, WAN, Wireless13 Kommentare

Hi, folgendes: Wir bekommen eine Glasfaser Leitung, Und das sollte Optional so aussehen: Ein Modem/Router für das WAN, ein ...

Netzwerkgrundlagen
Hi eine blöde frage. xD
Frage von 132954Netzwerkgrundlagen12 Kommentare

Also: Habe 2012 r2 essentials neuinstalliert, allerdings installiert diese version ja gleich diesen gangen AD kram mit, den hab ...

Batch & Shell
Trusted Sites für alle User auf dem PC einpflegen
Frage von xXTaKuZaXxBatch & Shell12 Kommentare

Aufgabestellung: Es sollen auf 1 PC (bzw. mehreren PCs) vertrauenswürdige Sites per Powershell eingetragen werden, die für alle User ...