SQL - Problem mit Cursor und Schleife
Hallo zusammen,
ich habe ein Problem, eine SQL Abfrage funktionstüchtig zu bekommen.
Entweder denke ich zu kompliziert, oder ich habe die völlig falsche Herransgehenweise, und hoffe Ihr könnt mir helfen.
Erst einmal zur Ausgangssituation.
DB: Oracle 11
Tabelle Abflug:
Zielstellung ist die Auflistung der Flüge mittels Cursors, aller Tage zwischen dem 13.11.2006 und 17.11.2006, sowie die Anzahl der Vormittagflüge (08:00-12:00) und Nachmittagsflüge(12:00-21:00)
Sind in dem gegebenen Zeitraum keine Flüge, soll "es finden keine Flüge statt" ausgegeben werden.
Die Ausgabe soll folgendes Format haben:
Der Select um die Flüge mir rauszusuchen ist ja nicht das Problem, bei mir scheitert es im Moment daran, die Flugzeiten auszuwerten, und entsprechend auszugeben.
Habe es im Moment mit sehr vielen IF Schleifen gemacht.
Anbei mal der Code, was ich bis jetzt so habe.
Ich habe mir hier für jeden Tag 2 Variablen (Früh / Spät) für die Flüge gemacht, und zähle diese aktuell hoch.
Das Ergebnis ist zwar richtig, aber nicht gerade "die feine englische Art", und zumal ist meine Variante sehr statisch.
Und ich habe bis jetzt das Problem noch nicht gelöst, mit dem "es finden keine Flüge statt".
Ich hoffe Ihr könnt mir hier behilflich sein.
Gruß
BadFsaadKl
ich habe ein Problem, eine SQL Abfrage funktionstüchtig zu bekommen.
Entweder denke ich zu kompliziert, oder ich habe die völlig falsche Herransgehenweise, und hoffe Ihr könnt mir helfen.
Erst einmal zur Ausgangssituation.
DB: Oracle 11
Tabelle Abflug:
desc osq01_abflug
Name Null Typ
-------- -------- -----------
AB_DATUM DATE
AB_ZEIT NUMBER(4,2)
#####
ab_datum ab_zeit
13.11.06 10,23
14.11.06 8,17
13.11.06 16,53
15.11.06 14,45
17.11.06 8,11
14.11.06 8,14
17.11.06 16,26
18.11.06 9,45
19.11.06 20,25
Zielstellung ist die Auflistung der Flüge mittels Cursors, aller Tage zwischen dem 13.11.2006 und 17.11.2006, sowie die Anzahl der Vormittagflüge (08:00-12:00) und Nachmittagsflüge(12:00-21:00)
Sind in dem gegebenen Zeitraum keine Flüge, soll "es finden keine Flüge statt" ausgegeben werden.
Die Ausgabe soll folgendes Format haben:
*******************************************************
13.11.06: Anzahl der Vormittagsfluege: 1
13.11.06: Anzahl der Nachmittagsfluege: 1
*******************************************************
14.11.06: Anzahl der Vormittagsfluege: 2
14.11.06: Anzahl der Nachmittagsfluege: es finden keine Fluege statt
*******************************************************
15.11.06: Anzahl der Vormittagsfluege: es finden keine Fluege statt
15.11.06: Anzahl der Nachmittagsfluege: 1
*******************************************************
16.11.06: Anzahl der Vormittagsfluege: es finden keine Fluege statt
16.11.06: Anzahl der Nachmittagsfluege: es finden keine Fluege statt
*******************************************************
17.11.06: Anzahl der Vormittagsfluege: 1
17.11.06: Anzahl der Nachmittagsfluege: 1
*******************************************************
Der Select um die Flüge mir rauszusuchen ist ja nicht das Problem, bei mir scheitert es im Moment daran, die Flugzeiten auszuwerten, und entsprechend auszugeben.
Habe es im Moment mit sehr vielen IF Schleifen gemacht.
Anbei mal der Code, was ich bis jetzt so habe.
set serveroutput on
declare
v_13_f number := 0;
v_13_s number := 0;
v_14_f number := 0;
v_14_s number := 0;
cursor cur_flug is
select ab_datum, ab_zeit
from osq01_abflug
where ab_datum between '13.11.2006' and '17.11.2006'
order by ab_datum;
begin
for rec_flug in cur_flug loop
if rec_flug.ab_datum = '13.11.2006' then
if rec_flug.ab_zeit between '8,00' and '12,00' then
v_13_f := v_13_f + 1;
elsif rec_flug.ab_zeit between '12,00' and '21,00' then
v_13_s := v_13_s + 1;
end if;
elsif rec_flug.ab_datum = '14.11.2006' then
if rec_flug.ab_zeit between '8,00' and '12,00' then
v_14_f := v_14_f + 1;
elsif rec_flug.ab_zeit between '12,00' and '21,00' then
v_14_s := v_14_s + 1;
end if;
end if;
end loop;
dbms_output.put_line('13.11.2006: Anzahl der Vormittagsfluege: ' || v_13_f );
dbms_output.put_line('13.11.2006: Anzahl der Nachmittagsfluege: ' || v_13_s );
dbms_output.put_line('******************************************');
dbms_output.put_line('14.11.2006: Anzahl der Vormittagsfluege: ' || v_14_f );
dbms_output.put_line('14.11.2006: Anzahl der Nachmittagsfluege: ' || v_14_s );
end;
/
Ich habe mir hier für jeden Tag 2 Variablen (Früh / Spät) für die Flüge gemacht, und zähle diese aktuell hoch.
Das Ergebnis ist zwar richtig, aber nicht gerade "die feine englische Art", und zumal ist meine Variante sehr statisch.
Und ich habe bis jetzt das Problem noch nicht gelöst, mit dem "es finden keine Flüge statt".
SQL> @cursor.sql
13.11.2006: Anzahl der Vormittagsfluege: 1
13.11.2006: Anzahl der Nachmittagsfluege: 1
******************************************
14.11.2006: Anzahl der Vormittagsfluege: 2
14.11.2006: Anzahl der Nachmittagsfluege: 0
SQL>
Ich hoffe Ihr könnt mir hier behilflich sein.
Gruß
BadFsaadKl
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 233870
Url: https://administrator.de/contentid/233870
Ausgedruckt am: 22.11.2024 um 13:11 Uhr