[NEWSboard IBMi Forum]
Seite 1 von 2 1 2 Letzte

Hybrid View

  1. #1
    Registriert seit
    Nov 2002
    Beiträge
    19
    Zitat Zitat von woki Beitrag anzeigen
    Das bekommst du mit execute immediate hin:

    Code:
    /free
      varFeldName = 'SaNr';
      varFeldWert = SaNr;
      varSQLStatement = 'SELECT SaName From SATEP01 Where ' + varFeldName + ' = ' + varFeldWert;
    /end-free
    
    c/exec sql                        
    c+ Execute immediate :varSQLStatement
    C/end-exec
    so weit war ich am Anfang auch

    Aber bei genauem Betrachten bringt mich das nicht weiter, denn ich weiss ja nicht, welches Feld ich benötige... das ganze ist ja variabel...
    In meinem Beispiel ist die Hostvariable jetzt SaNr... kann aber auch ein ganz anderes Feld sein, was abgefragt werden soll...

    Ich formuliere meine Frage mal ganz konkret:
    Wie komme ich an den Inhalt eines Feldes, dessen Name in einer Programmvariable steht ???

  2. #2
    Registriert seit
    Apr 2004
    Beiträge
    105
    Zitat Zitat von VAHLE Beitrag anzeigen
    Ich formuliere meine Frage mal ganz konkret:
    Wie komme ich an den Inhalt eines Feldes, dessen Name in einer Programmvariable steht ???
    damit :

    Code:
    d sqlStatement    s           1024    inz('') 
    d myPgmVar        s            128
    
     /free                                          
      myPgmVar = 'MyFeld1';                           
      sqlStatement = 'select ' + %trim(myPgmVar) + ' ' +    
                     'from myLib/MyFile ';   
    
     /end-free   
                                       
    C/exec sql                           
    C+ prepare s1 FROM :sqlStatement     
    c/end-exec                           
                                                                              
    C/exec sql                           
    C+ declare c01 cursor for s1         
    c/end-exec                           
    
    etc...
    oder verstehe ich deine Frage immer noch nicht? Hast du ein konkretes Bespiel?

  3. #3
    Registriert seit
    Nov 2002
    Beiträge
    19
    Zitat Zitat von woki Beitrag anzeigen
    damit :

    Code:
    d sqlStatement    s           1024    inz('') 
    d myPgmVar        s            128
    
     /free                                          
      myPgmVar = 'MyFeld1';                           
      sqlStatement = 'select ' + %trim(myPgmVar) + ' ' +    
                     'from myLib/MyFile ';   
    
     /end-free   
                                       
    C/exec sql                           
    C+ prepare s1 FROM :sqlStatement     
    c/end-exec                           
                                         
                                         
    C/exec sql                           
    C+ declare c01 cursor for s1         
    c/end-exec                           
                                         
    c/exec sql                           
    c+ open c01                          
    c/end-exec    
    
    etc...
    Danke. Bringt mich aber auch nicht weiter...

    Denn ich möchte in der Where-Bedingung den Vergleichswert variabel haben...
    Wenn ich das im RPG "hart" codieren würde, dann mache ich das ja über den Vergleich mit einer Hostvariablen.
    Bsp.: "... Where Feld1 = :PgmFeld"

    Aber eben diese Hostvariablen kann man im dynamischen SQL ja nicht verwenden...
    Ich kenne also in dem Fall nur den Feldnamen. In meinem Beispiel "PgmFeld"... Und da hapert es momentan bei mir, wie ich an den Inhalt eines Feldes komme, dessen Name in einem Programmfeld steht...

  4. #4
    Registriert seit
    Feb 2001
    Beiträge
    20.696
    SO dynmaisch geht das ja nun auch wieder nicht.
    Du musst dir da schon mal was einfallen lassen.
    Z.B.:
    VarPos = %scan(':':MySql);
    if VarPos > *zero;
    select;
    when %subst(MySQL:VarPos:6) = 'MyVar1';
    MySQL = %replace(MySQL:':MyVar1':'''' + MyVar1 + '''');
    when %subst(MySQL:VarPos:6) = 'MyVar2';
    MySQL = %replace(MySQL:':MyVar2':%char(MyVar2));
    endsl;
    endif;
    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

  5. #5
    Registriert seit
    Nov 2002
    Beiträge
    19
    Zitat Zitat von Fuerchau Beitrag anzeigen
    SO dynmaisch geht das ja nun auch wieder nicht.
    Du musst dir da schon mal was einfallen lassen.
    Z.B.:
    VarPos = %scan(':':MySql);
    if VarPos > *zero;
    select;
    when %subst(MySQL:VarPos:6) = 'MyVar1';
    MySQL = %replace(MySQL:':MyVar1':'''' + MyVar1 + '''');
    when %subst(MySQL:VarPos:6) = 'MyVar2';
    MySQL = %replace(MySQL:':MyVar2':%char(MyVar2));
    endsl;
    endif;
    Dann müsste ich im RPG aber auch alle möglichen Feldnamen abfangen...
    Genau das möchte ich ja nicht. Ich möchte das so dynamisch, wie möglich gestalten.

    Gibt es keine Möglichkeit, im RPG mit variablen Feldnamen zu arbeiten ?

  6. #6
    Registriert seit
    Mar 2002
    Beiträge
    5.365
    nur ein paar Anmerkungen:
    - dynamic SQL kann sehr wohl mit Hostvariablen, der prepareString enthält dann ? als Platzhalter, dei beim execute übergeben werden
    - diese Variablen müssen, wie alle Namen zur Compiletime bekannt sein (wo sollen sie auch zur Laufzeit herkommen)
    - gehen tut letztlich sogut wie alles, aber ob das Design was taugt, das ist in diesem Fall für mich noch eine nicht beantwortete Frage.

    D*B
    AS400 Freeware
    http://www.bender-dv.de
    Mit embedded SQL in RPG auf Datenbanken von ADABAS bis XBASE zugreifen
    http://sourceforge.net/projects/appserver4rpg/

  7. #7
    Registriert seit
    Nov 2002
    Beiträge
    19
    Die Platzhalter (?) waren mir auch bekannt, aber das löst mein Problem leider auch nicht.

    Vergesst bitte einmal diese spezielle Aufgabenstellung hier.
    Ist es überhaupt irgendwie möglich, an den Inhalt eines Feldes zu kommen, dessen Name selbst Inhalt eines Programmfeldes ist ?


    (php kann ja z.B. auch mit variablen Feldnamen umgehen (z.B. var1=@FeldName - glaube ich)

  8. #8
    Registriert seit
    Mar 2002
    Beiträge
    5.365
    wie ich bereits sagte, geht viel und auch dieses, ich habe allerdings keinen Bock mich auf Diskussionen einzulassen, nach dem Muster: das war mir bekannt, hilft mir aber auch nicht weiter...

    Zitat Zitat von VAHLE Beitrag anzeigen
    Die Platzhalter (?) waren mir auch bekannt, aber das löst mein Problem leider auch nicht.

    Vergesst bitte einmal diese spezielle Aufgabenstellung hier.
    Ist es überhaupt irgendwie möglich, an den Inhalt eines Feldes zu kommen, dessen Name selbst Inhalt eines Programmfeldes ist ?


    (php kann ja z.B. auch mit variablen Feldnamen umgehen (z.B. var1=@FeldName - glaube ich)
    AS400 Freeware
    http://www.bender-dv.de
    Mit embedded SQL in RPG auf Datenbanken von ADABAS bis XBASE zugreifen
    http://sourceforge.net/projects/appserver4rpg/

  9. #9
    Registriert seit
    Nov 2002
    Beiträge
    19
    @Bender:

    Entschuldigung, aber ich bin mir keiner Schuld bewusst, dass ich mich hier irgendwie im Ton vergriffen haben könnte...

    Ich hab mir heute den ganzen Morgen lang den Kopf über dieses Problem zerbrochen und bin bereits an allen hier genannten Lösungsansätzen gescheitert.

    Warum Du Dich jetzt persönlich angegriffen fühlst, kann ich irgendwie nicht ganz nachvollziehen.

  10. #10
    Registriert seit
    Jan 2001
    Beiträge
    133
    Also ich habe das Thema auch schon mal diskutiert. siehe http://www.newsolutions.de/forum-sys...feldnamen.html
    Jedoch führte auch das damals zu keinem Ergebnis. Ich finde es auch immer recht schade, wenn man am Ende der Diskussion dann nur den Tip bekommt, mal über sein "Konzept dahinter nachzudenken" Wer so ein Problem hat, hat meistens auch eine anspruchsvolle Aufgabe dahinter, da kann sich der geneigte Schreiber sicher sein. Und das Argument mit den anderen Programmiersprachen die das auch nicht oder eben doch können, weil es nur Interpreter Sprachen sind, zieht auch irgendwie nicht. Wat issn mit Delphi und Pascal ??? Die können das und sind ... na ?

    Also Olli ich bin auf Deiner Seite, suche auch noch nach einer Lösung, wenn auch nicht so intensiv, weil ich hab leider wie wir alle ja noch mehr zutun. Im Moment arbeite ich damit, das ich den kompletten SQL String aus einer Datenbank zusammenbaue, in der vorher die Feldnamen und Definitionen abgelegt sind. Man ist aber immer noch bei den Inhalten eingeschränkt und leider kann man nicht nativ mit read und write auf die Daten losgehen, sondern nur mit SQL.

    Wenn Murphy und alle Götter der Programmierung mir hold sind und ich eine Lösung habe, werde ich davon sicher hier zu berichten wissen. Ich bin mir sicher es wird eine Lösung geben, wie auch immer die aussieht.

    Mögen die Bits mit uns sein !

    Thomas

  11. #11
    Registriert seit
    Jan 2006
    Beiträge
    82
    Hallo,

    ich bin auch eurer Meinung und bin auch an der Lösung interessiert, denn:

    GEHT NICHT, GIBTS NICHT

  12. #12
    Registriert seit
    Mar 2002
    Beiträge
    5.365
    Wir sind wieder mal an einer Stelle, wo es an einer genauen Beschreibung fehlt, welches Problem eigentlich gelöst werden soll. Hier werden nämlich schon wieder zwei Dinge vermischt.
    @Liebhoff: siehe originärer Thread!
    Zu diesem Thema hier:
    Zu Interpreter Sprachen hat Baldur schon was gesagt, hier sei nur ergänzt, dass hier Flexibilität mit abnehmender Sicherheit erkauft wird: Fehler die zur Compiletime erkannt werden, treten nicht zur Laufzeit auf. Zu Delphi und Pascal sei angemerkt, dass originäres Pascal das keineswegs konnte und sich das auch nicht mit der eigentlichen Sprachphilosophie verträgt. Delphi kann sowas, ähnlich wie Java: dieser Mechanismus nennt sich Reflection und bezieht sich auch nicht auf alles innerhalb einer Klasse, sondern im wesentlichen auf die Exporte. Den Weg das in RPG zu nutzen habe ich in einem früheren Posting beschrieben.
    Zum Design von sowas: auch in Java und Delphi muss man gute Gründe haben das zu nutzen, denn man bekommt nix für lau. Reflection hebelt Typprüfung aus und man kriegt Runtime Fehler (Type missmatch beim upcast), die man sonst garnicht bekommen kann, weil der Compiler einen davon abhält.
    Im Falle von RPG muss man hier noch vorsichtiger sein, weil die RPG Runtime nich typsicher ist; der Compiler prüft zuwenig zur Compiletime und die Runtime weiss bei Pointern nicht auf was sie da zeigt.
    Fazit: Wer unbedingt Reflection benötigt (ja, das gibt es wirklich), der sollte dafür eine Programmiersprache benutzen, die das vernünftig unterstützt. Wer das mit Gewalt (Dump auswerten ist ja wohl ein Scherz?!) in RPG versucht, liegt genauso schief, wie jemand, der eine FIBU in CL schreiben will.

    D*B
    AS400 Freeware
    http://www.bender-dv.de
    Mit embedded SQL in RPG auf Datenbanken von ADABAS bis XBASE zugreifen
    http://sourceforge.net/projects/appserver4rpg/

Similar Threads

  1. Variable Feldnamen
    By Liebhoff in forum IBM i Hauptforum
    Antworten: 20
    Letzter Beitrag: 11-03-08, 09:47
  2. "Environment variable not found"
    By Kampi4 in forum NEWSboard Programmierung
    Antworten: 5
    Letzter Beitrag: 09-10-06, 10:19
  3. Variable Zahlenkonvertieren
    By Xanas in forum NEWSboard Programmierung
    Antworten: 4
    Letzter Beitrag: 28-08-06, 12:21
  4. cl declare variable
    By TARASIK in forum IBM i Hauptforum
    Antworten: 2
    Letzter Beitrag: 24-08-06, 10:09
  5. String mit HexInhalt muss als Hex-Wert in Variable
    By cheffe1008 in forum NEWSboard Programmierung
    Antworten: 7
    Letzter Beitrag: 16-05-06, 07:45

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • You may not post attachments
  • You may not edit your posts
  •