Oracle SQL Subselect und LEFT JOIN
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!
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!
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 164647
Url: https://administrator.de/forum/oracle-sql-subselect-und-left-join-164647.html
Ausgedruckt am: 23.04.2025 um 05:04 Uhr
1 Kommentar
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
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