Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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

Unterabfragen SQL

Frage Entwicklung Datenbanken

Mitglied: Legionista

Legionista (Level 1) - Jetzt verbinden

19.12.2012 um 10:53 Uhr, 1708 Aufrufe, 3 Kommentare

Guten Tag,

es ist mir nicht ganz verstädnlich, wann man in SQL eine Unterabfrage macht bzw. wann es Sinn macht. Dies möchte ich am folgenden Beispiel verdeutlichen:

Richtig lautet es:

SELECT
tblFilme.Filmtitel, tblFilme.Länge
FROM

tblFilme
WHERE
tblFilme.Länge >

(SELECT
Länge
FROM
tblFilme
WHERE
Filmtitel ='Gladiator')
ORDER BY tblFilme.Länge DESC


Ich hätte gedachzt es würde auch so gehen:

SELECT
tblFilme.Filmtitel, tblFilme.Länge
FROM

tblFilme
WHERE
tblFilme.Länge > Filmtitel ='Gladiator'
ORDER BY tblFilme.Länge DESC

Leider ist dies nicht der Fall. Kann mir jeman derklären woran das liegt?
Mitglied: Firepower
19.12.2012 um 12:31 Uhr
Hi,
bei der oberen Abfrage fragst du nach dem Wert "Länge" vom Filmtitel "Gladiator",
dies ist ja auch das was du als Vergleichsgröße benötigst.

Unten kann die Abfrage nicht funktionieren, da du kein eindeutiges Ergebnis hast mit dem du größer als vergleichst.

Richtig wäre auch, wenn du in der Abfrage direkt den Wert angeben würdest, also:

SELECT
tblFilme.Filmtitel, tblFilme.Länge
FROM

tblFilme
WHERE
tblFilme.Länge > 150
ORDER BY tblFilme.Länge DESC

jenachdem was als Wert in Länge angegeben ist.

Da du aber einen Wert vergleichen willst, welcher selber nur über eine Abfrage zu erreichen ist,
daher die nötige Unterabfrage.


Greetz
Firepower
Bitte warten ..
Mitglied: filippg
19.12.2012 um 20:22 Uhr
Hallo,

Ich hätte gedachzt es würde auch so gehen: [...]
Leider ist dies nicht der Fall. Kann mir jeman derklären woran das liegt?
Äh... ne. Kannst du erklären, wie du auf die Idee kommst, dass es funktionieren sollte?
Im besten Fall würde "Filmtitel = 'Gladiator'" eine ganze Zeile zurückliefern, und eine Zelle (tblFilme.Länge) kannst du nicht mit einer Zeile vergleichen.

Gruß

Filipp
Bitte warten ..
Mitglied: nxclass
19.12.2012 um 20:49 Uhr
01.
SELECT 
02.
  f1.Filmtitel, 
03.
  f1.Länge 
04.
FROM tblFilme f1 
05.
  INNER JOIN tblFilme f2 ON f1.Länge > f2.Länge 
06.
WHERE 
07.
  f2.Filmtitel = 'Gladiator' 
08.
ORDER BY f1.Länge DESC
.. sollte auch gehen - beachte den JOIN über die selbe Tabelle mit unterschiedlichem Alias
Bitte warten ..
Ähnliche Inhalte
Datenbanken
gelöst SQL - nur Daten mit niedrigster ID ausgeben (1)

Frage von winscheil zum Thema Datenbanken ...

Festplatten, SSD, Raid
SQL Entwicklungsserver mit RAID1 oder RAID5 (4)

Frage von AndreasOC zum Thema Festplatten, SSD, Raid ...

Datenbanken
gelöst MS SQL - primary Datei verkleinern (6)

Frage von Thomas2 zum Thema Datenbanken ...

Neue Wissensbeiträge
Batch & Shell

Batch zum Zurücksetzen eines lokalen Profils

Tipp von Mr.Error zum Thema Batch & Shell ...

RedHat, CentOS, Fedora

Fedora, RedHat, Centos: DNS-Search Domain setzen

(13)

Tipp von Frank zum Thema RedHat, CentOS, Fedora ...

Heiß diskutierte Inhalte
Exchange Server
Microsoft Exchange Weiterleitung mit anderer primären E-Mail Adresse (14)

Frage von Rene12345 zum Thema Exchange Server ...

Windows Userverwaltung
gelöst Wie verfahrt Ihr mit den Windows-Benutzerkonten und -dateien von ausgeschiedenen Mitarbeitern? (14)

Frage von Bl0ckS1z3 zum Thema Windows Userverwaltung ...

LAN, WAN, Wireless
VPN Tunnel aufbauen (13)

Frage von Hajo2006 zum Thema LAN, WAN, Wireless ...

Microsoft Office
Saubere HTML aus Word-Dokument (13)

Frage von peterpa zum Thema Microsoft Office ...