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

Probleme bei einem UNION SELECT

Mitglied: godlie

godlie (Level 2) - Jetzt verbinden

05.03.2010 um 08:46 Uhr, 2953 Aufrufe, 5 Kommentare

Hallo,

ich knabbere gerauem Zeit an einem Query herum, mir ist soweit schon gelungen meine Ganzen Daten aus den Sidetables zu holen ich scheitere nur daran die Daten aus der positions Table noch zu sortieren nach ihrer posNum.
Es soll das ganze in diese Richtung der Darstellung laufen:

Project 0x1
-- Pos 01
-- Pos 02
-- Pos 03

Was ich derzeit habe ist das hier:

Project 0x1
-- Pos 03
-- Pos 01
-- Pos 02

[code]
SELECT p.pid AS dip,p.prNum,"",p.order,p.description,"",cus.name FROM `projectList_projects` AS p
JOIN customers AS cus ON cus.cid = p.customerID)
UNION
(SELECT pd.pid,pd.prNum,pp.posNum,"",pp.description,pp.drawingNum,cus.name FROM `projectList_positions` AS pp
JOIN projectList_projects AS pd ON pd.pID = pp.pID
JOIN customers AS cus ON cus.cid = pd.customerID)
ORDER BY dip
[/code]

Nachdem es ja so ist das die Sortierkritieren im ersten Select getätig werden müssen steig ich gedanklich aus...
Dank und Gruß im voraus
Mitglied: Bolle97
05.03.2010 um 09:23 Uhr
Hallo,

ich kenne es genau andersrum, das "ORDER BY" kommt als Letztes.
Desweiteren kannst Du bei einigen Datenbanken das ORDER BY mit den Positionsnummern der selektierten Spalten angeben, z.B. ORDER BY 1,5,3

Gruß René
Bitte warten ..
Mitglied: Biber
05.03.2010 um 10:03 Uhr
Moin godlie,

versuch es so:
01.
Select x.dip, x.prnum, x.posnum, x.order, x.description, x.drawingnum, x.name From (
02.

03.
SELECT p.pid AS dip,p.prNum,"" as posnum, p.order,p.description,"" as DrawingNum,cus.name FROM `projectList_projects` AS p
04.
JOIN customers AS cus ON cus.cid = p.customerID)
05.
UNION ALL
06.
(SELECT pd.pid,pd.prNum,pp.posNum,"",pp.description,pp.drawingNum,cus.name FROM `projectList_positions` AS pp
07.
JOIN projectList_projects AS pd ON pd.pID = pp.pID
08.
JOIN customers AS cus ON cus.cid = pd.customerID)
09.
) as x
10.
ORDER BY x.dip, x.posnum
Die beiden namenlosen Felder in deinem ersten Teil-Select habe ich mit Namen versehen.
Ich bin zwar nicht ganz schlau geworden, nach was du nun sortieren willst... aber an das ORDER BY kommst du ja jetzt ran.

Auf keinen Fall macht es Sinn, schon innerhalb eines der Teil-SELECTs zu sortieren... es wird ja so oder so der komplette Union am Ende neu arrangiert per ORDER BY.

Grüße
Biber
Bitte warten ..
Mitglied: godlie
08.03.2010 um 16:46 Uhr
Hallo,
Die Idee ist ja schon nicht schlecht, nur lauf ich da in einen "every derived TAble musst have its own Alias"Fehler rein.
Aber irgendwie lässt sich das net so recht auflösen...

01.
Select x.dip, x.prnum, x.posnum, x.order, x.description, x.drawingnum, x.name From (
02.

03.
SELECT p.pid AS dip,p.prNum,"" as posnum, p.order,p.description,"" as DrawingNum,cus.name FROM `projectList_projects` AS p
04.
JOIN customers AS cus ON cus.cid = p.customerID) AS y
05.
UNION ALL
06.
SELECT * FROM (
07.
SELECT pd.pid,pd.prNum,pp.posNum,"",pp.description,pp.drawingNum,cus.name FROM `projectList_positions` AS pp
08.
JOIN projectList_projects AS pd ON pd.pID = pp.pID
09.
JOIN customers AS cus ON cus.cid = pd.customerID
10.
) AS z 
11.
) as x
12.
ORDER BY x.dip, x.posnum
Bitte warten ..
Mitglied: Biber
08.03.2010 um 21:40 Uhr
Moin godlie,

na ja, der einzige "doppelt" verwendete Alis ist doch der Alias "cus" für die Customers-Table.

Ändere doch da mal einen der beiden von cus in Couscous oder in cus2.
01.
Select x.dip, x.prnum, x.posnum, x.order, x.description, x.drawingnum, x.name From (
02.

03.
SELECT p.pid AS dip,p.prNum,"" as posnum, p.order,p.description,"" as DrawingNum,cus1.name FROM `projectList_projects` AS p
04.
JOIN customers AS cus1 ON cus1.cid = p.customerID)
05.
UNION ALL
06.
(SELECT pd.pid,pd.prNum,pp.posNum,"",pp.description,pp.drawingNum,cus2.name FROM `projectList_positions` AS pp
07.
JOIN projectList_projects AS pd ON pd.pID = pp.pID
08.
JOIN customers AS cus2 ON cus2.cid = pd.customerID)
09.
) as x
10.
ORDER BY x.dip, x.posnum
Wenn es jetzt nicht fliegt, dann muss ich es wohl doch testen...

Grüße
Biber
Bitte warten ..
Mitglied: godlie
09.03.2010 um 08:20 Uhr
Hallo Biber,
auf das Problem bin ich auch schon gestoßen....
Ich glaube das er sich hier mit dem Subquery vertut bzw. dort noch irgendwo ein Alias erwartet
aber irgendwie will das ganze nicht so recht.
Falls Demo Daten brauchst kann ich dir welche zukommen lassen.

Dank und Gruß
Bitte warten ..
Ähnliche Inhalte
Datenbanken
ROW-NUMBER über UNION Select
gelöst Frage von SolardubDatenbanken6 Kommentare

MSSQL 2008: Ich hatte vorher eine Abfrage, nun brauche ich zwei Select's die mit UNION gemeinsam abgefragt werden. Dazu ...

Batch & Shell
Powershell Select
gelöst Frage von shwatsonBatch & Shell5 Kommentare

Hallo Community! Zu meinem Problem, ich habe mir ps1 und eine txt Datei erstellt, und versuche nun mit der ...

Batch & Shell
Powershell select-string -pattern
gelöst Frage von LianenSchwingerBatch & Shell2 Kommentare

Hallo, ich muss auf die schnelle ca. 1000 EDIFACT Dateien auswerten. Dazu versuche ich mich gerade in Powershell einzuarbeiten. ...

PHP

Chained select - abhängige dropdowns

gelöst Frage von jensgebkenPHP15 Kommentare

hallo gemeinschaft habe zwei dropdown menüs, die voneinander abhängig sind es sind die menüs gebiet reederei das ist die ...

Neue Wissensbeiträge
Windows 7
Updategängelung auf Windows 10, die zweite
Information von Penny.Cilin vor 1 TagWindows 7

Hallo, da Windows 7 im kommenden Jahr nicht mehr supportet wird, werden Nutzer von Window 7 home premium wieder ...

Internet
EU-Urheberrechtsreform: Zusammenfassung
Information von Frank vor 3 TagenInternet1 Kommentar

Auf golem.de gibt es eine Analyse von Friedhelm Greis, der das Thema EU-Urheberrechtsreform gut und strukturiert zusammenfasst. Zwar haben ...

Microsoft Office

Office365 Schwachstellen bei Sicherheit und Datenschutz

Information von Penny.Cilin vor 4 TagenMicrosoft Office7 Kommentare

Auf Heise+ gibt es einen Artikel bzgl. Office365 Schwachstellen. Das ist noch ein Grund mehr seine Daten nicht in ...

Sicherheit
Schwachstellen in VPN Clients
Tipp von transocean vor 6 TagenSicherheit2 Kommentare

Moin, es gibt Sicherheitslücken bei VPN Clients namhafter Hersteller, wie man hier lesen kann. Gruß Uwe

Heiß diskutierte Inhalte
Notebook & Zubehör
Hardware defekt ?
Frage von mausemuckelNotebook & Zubehör14 Kommentare

Hallo und ein schönes Osterfest an alle. Ich benötige mal euer Schwarm wissen. Ich habe hier ein Notebook Lenovo ...

LAN, WAN, Wireless
Lancom und VLANs
Frage von TimmheLAN, WAN, Wireless11 Kommentare

Hallo an alle ich habe momentan ein sehr merkwürdiges problem bei dem ich nicht mehr weiter komme und hoffe ...

Netzwerkmanagement
Konfiguration von IPv6 in einer Domäne mit DHCP
Frage von gnoovyNetzwerkmanagement10 Kommentare

Hi Zusammen, ich bin gerade etwas am verzweifeln. Ich habe eine Testumgebung aufgebaut, um mich in das Thema IPv6 ...

Virtualisierung
Unix System virtualisieren
Frage von BananenmeisterVirtualisierung10 Kommentare

Hallo Zusammen, Ich möchte gerne eine Virtualisierungs-Software auf meinem kleinen ML Server installieren um einige Unix Systeme zu virtualisieren. ...