AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein [Oracle:SQL] Subquery mit Bezug auf "Superquery" für View
Thema durchsuchen
Ansicht
Themen-Optionen

[Oracle:SQL] Subquery mit Bezug auf "Superquery" für View

Ein Thema von sirius · begonnen am 10. Nov 2009 · letzter Beitrag vom 12. Nov 2009
 
Elvis

Registriert seit: 25. Nov 2005
Ort: München
1.909 Beiträge
 
Delphi 2010 Professional
 
#3

Re: [Oracle:SQL] Subquery mit Bezug auf "Superquery&

  Alt 10. Nov 2009, 22:21
Wie wird denn auf die Daten zugegriffen?
Denn du könntest dir ein Package schrieben, welches sich passend zu einer ID ein SQL mit Spalten für alle ID2s baut.

Ist jetzt als Trockenübung aus den Fingern gesaugt, also Nachsicht büddeshön!


SQL-Code:
create package CrosstabThingy authid current_user as
  function GetCrossTabFor(valueID in Integer) return sys_refcursor;
end;

create package body CrosstabThingy as
  function GetCrossTabFor(valueID in Integer) return sys_refcursor is
    result sys_refcursor;
    sqlStatement clob;
    valueIndex Integer := 0;
  begin
    sqlStatement := 'SELECT Zeit';

    for childID in (select ID2 from mytable where ID1 = valueID) loop
      valueIndex := valueIndex + 1;
      sqlStatement := sqlStatement ||
                      ',(SELECT Messwert from mytable where ID2 = '||
                      childID.ID2||') as Value'||to_Char(valueIndex, 'tm00');
    end loop;

    sqlStatement := sqlStatement || ' from myTable where ID1 = :id';
    open result for to_Char(sqlStatement)
      using valueID;
    return result;
  end;
end;
Per ODBC würde das so ausgeführt werden können:
{call CrosstabThingy.GetCrossTabFor(5000)} Je nachdem wie du drauf zugreifst ginge auch sowas:
SQL-Code:
select Zeit,
       cursor(select ID2, Messwert
              from mytable
              where ID1 = t.ID1) Values
from mytable t
where ...
Oracle hat auch eine Menge XML Funktionen parat, mussu nur sagen wofür das nachher benutzt werden soll.
Robert Giesecke
I’m a great believer in “Occam’s Razor,” the principle which says:
“If you say something complicated, I’ll slit your throat.”
  Mit Zitat antworten Zitat
 


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:41 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz