Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

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

Oracle SQL Subselect und LEFT JOIN

Frage Entwicklung Datenbanken

Mitglied: mwks2802

mwks2802 (Level 1) - Jetzt verbinden

15.04.2011, aktualisiert 10:01 Uhr, 5182 Aufrufe, 1 Kommentar

Hallo,

ich bin absoluter Anfänger im Bereich ORACLE Datenbanken.
Ich hoffe, dass jemand mir weiterhelfen kann....

Ich habe folgendes Problem:

Ich muss möglichst einfach aus zwei Tabellen Werte zusammen führen.
Aus Tabelle 1 brauche ich alle Einträge und aus Tabelle 2 den jüngsten zu der ID passenden Eintrag.
MySQL hat meine Query ohne weiteres ausgeführt und ein Ergebnis geliefert, aber Oracle gibt mir eine 'false' zurück.

hier die Tabellen Struktur:

Tabelle 1:

-- Tabellenstruktur für Tabelle `ezsearch_search_phrase`
--

CREATE TABLE IF NOT EXISTS `ezsearch_search_phrase` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`phrase` varchar(250) COLLATE utf8_unicode_ci DEFAULT NULL,
`phrase_count` int(11) DEFAULT '0',
`result_count` int(11) DEFAULT '0',
PRIMARY KEY (`id`),
UNIQUE KEY `ezsearch_search_phrase_phrase` (`phrase`),
KEY `ezsearch_search_phrase_count` (`phrase_count`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=5 ;


Tabelle 2:

-- Tabellenstruktur für Tabelle `ezsearch_return_count`
--

CREATE TABLE IF NOT EXISTS `ezsearch_return_count` (
`count` int(11) NOT NULL DEFAULT '0',
`id` int(11) NOT NULL AUTO_INCREMENT,
`phrase_id` int(11) NOT NULL DEFAULT '0',
`time` int(11) NOT NULL DEFAULT '0',
PRIMARY KEY (`id`),
KEY `ezsearch_return_cnt_ph_id_cnt` (`phrase_id`,`count`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=9 ;



Meine Abfrage für MySQL:

SELECT esp.*,
( SELECT MAX( time )
FROM ezsearch_return_count
WHERE ( phrase_id = esp.id )
) as time
FROM ezsearch_search_phrase as esp
LEFT JOIN ezsearch_return_count AS erc
ON esp.id = erc.phrase_id
GROUP BY esp.id;


Danke für eure Hilfe!
Mitglied: Indrador
21.04.2011 um 13:18 Uhr
Hmmmm entweder begreife ich nicht was das tun soll und ich stehe auf dem Schlauch....
du holst dir nichts aus dem Left Join, der ist einfach nur da
und das group by ist auch unnötig, da du dir bereits den max Wert zu der ID geholt hast.

Damit solltest du dir das holen können, was du oben beschrieben hast, alles aus esp und den max wert aus der count.

SELECT esp.*,
(
SELECT MAX( time )
FROM ezsearch_return_count
WHERE ( phrase_id = esp.id )
) as time
FROM ezsearch_search_phrase as esp

Falls Ziel der Übung sein soll, dir das Value von count zu holen, wo der time = max(time) ist, kann das folgendermaßen aussehen:

SELECT esp.*,
(
Select c.Count
from ezsearch_return_count as c
where c.phrase_id = esp.id and c.time = (
SELECT MAX( time )
FROM ezsearch_return_count as c2
WHERE ( c2.phrase_id = esp.id )
)
) as Count
FROM ezsearch_search_phrase as esp
Bitte warten ..
Ähnliche Inhalte
Datenbanken
gelöst SQL Problem (Subselect? Having?) (5)

Frage von EricAG3 zum Thema Datenbanken ...

Datenbanken
SQL - Mehrere Tabellen über JOINS verketten (1)

Frage von Gwahlers zum Thema Datenbanken ...

Datenbanken
gelöst SQL ORDER BY und Join mit 2 Tabellen (7)

Frage von Dipps zum Thema Datenbanken ...

Datenbanken
gelöst MySQL Abfrage um JOIN erweitern (14)

Frage von datadexx zum Thema Datenbanken ...

Neue Wissensbeiträge
Ubuntu

Ubuntu 17.10 steht zum Download bereit

Information von Frank zum Thema Ubuntu ...

Datenschutz

Autofahrer-Pranger - Bewertungsportal illegal

(8)

Information von BassFishFox zum Thema Datenschutz ...

Windows 10

Neues Win10 Funktionsupdate verbuggt RemoteApp

(6)

Information von thomasreischer zum Thema Windows 10 ...

Microsoft

Die neuen RSAT-Tools für Win10 1709 sind da

(2)

Information von DerWoWusste zum Thema Microsoft ...

Heiß diskutierte Inhalte
Router & Routing
Allnet - VDSL2 Modem - SFP (mini-GBIC) (20)

Frage von Dobby zum Thema Router & Routing ...

Voice over IP
DeutschlandLAN IP Voice Data M Premium, Erfahrung mit Faxgeräte? (17)

Frage von liquidbase zum Thema Voice over IP ...

Windows 10
Windows 10 Ordnerfreigabe (15)

Frage von Xaero1982 zum Thema Windows 10 ...

Monitoring
Netzwerk-Monitoring Software (15)

Frage von Ghost108 zum Thema Monitoring ...