Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. [gelöst] Skript - JS und SQL Abfrage - Erg undifined

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    16
    1
    236

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    4.5k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.3k

[gelöst] Skript - JS und SQL Abfrage - Erg undifined

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
15 Beiträge 2 Kommentatoren 364 Aufrufe 1 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • michl75M Offline
    michl75M Offline
    michl75
    schrieb am zuletzt editiert von michl75
    #1

    Hallo,
    ich versuche gerade über ein Blockly und JS-Funktion eine Abfrage zu machen. Bild vom Block anbei und Code...

    Leider erhalte ich immer nur die "Ausgabe" undefined... Könnte mir einer helfen, was ich da falsch mache?

    io1.PNG

    _erg = "";
    _t = new Date().getTime();
    _sql = "SELECT AVG(val) FROM iobroker.ts_number where id = 218 and ts > (" + x + ")";
    sendTo('sql.0', 'query', _sql, function (result) 
    {
        _erg = JSON.stringify(result.result);
        return _erg;
    });
    

    Viele Grüß M.

    paul53P 1 Antwort Letzte Antwort
    0
    • michl75M michl75

      Hallo,
      ich versuche gerade über ein Blockly und JS-Funktion eine Abfrage zu machen. Bild vom Block anbei und Code...

      Leider erhalte ich immer nur die "Ausgabe" undefined... Könnte mir einer helfen, was ich da falsch mache?

      io1.PNG

      _erg = "";
      _t = new Date().getTime();
      _sql = "SELECT AVG(val) FROM iobroker.ts_number where id = 218 and ts > (" + x + ")";
      sendTo('sql.0', 'query', _sql, function (result) 
      {
          _erg = JSON.stringify(result.result);
          return _erg;
      });
      

      Viele Grüß M.

      paul53P Offline
      paul53P Offline
      paul53
      schrieb am zuletzt editiert von paul53
      #2

      @michl75

      return _erg;
      

      erfolgt aus einer Callback-Funktion, also erst nachdem die Funktion SQLabfrage(x) beendet wurde.

      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

      michl75M 1 Antwort Letzte Antwort
      0
      • paul53P paul53

        @michl75

        return _erg;
        

        erfolgt aus einer Callback-Funktion, also erst nachdem die Funktion SQLabfrage(x) beendet wurde.

        michl75M Offline
        michl75M Offline
        michl75
        schrieb am zuletzt editiert von michl75
        #3

        @paul53 Danke für deine Antwort... verstanden hab ich das allerdings nicht.. bin jetzt da kein Experte.. Versuche durch suchen, lesen und ausprobieren... auch wenn ich mir Mühe gebe. Könntest du mir das erklären?
        Viele Dank......

        EDIT:
        Der Ansatz besser?

        function ergebnis(result) {
          log('Durchschnitt ist: '+ JSON.stringify(result));
          return result.result[0];
        }
        sendTo('sql.0', 'query', 'SELECT AVG(val) FROM iobroker.ts_number where id = 218 and ts > ' + x, ergebnis);
        

        ,
        io1.PNG

        paul53P 1 Antwort Letzte Antwort
        0
        • michl75M michl75

          @paul53 Danke für deine Antwort... verstanden hab ich das allerdings nicht.. bin jetzt da kein Experte.. Versuche durch suchen, lesen und ausprobieren... auch wenn ich mir Mühe gebe. Könntest du mir das erklären?
          Viele Dank......

          EDIT:
          Der Ansatz besser?

          function ergebnis(result) {
            log('Durchschnitt ist: '+ JSON.stringify(result));
            return result.result[0];
          }
          sendTo('sql.0', 'query', 'SELECT AVG(val) FROM iobroker.ts_number where id = 218 and ts > ' + x, ergebnis);
          

          ,
          io1.PNG

          paul53P Offline
          paul53P Offline
          paul53
          schrieb am zuletzt editiert von paul53
          #4

          @michl75 sagte: Könntest du mir das erklären?

          sendTo() wird asynchron abgearbeitet, d.h. es wird nur gestartet, aber nicht gewartet bis es abgearbeitet ist. Erst wenn sendTo() fertig ist, ruft es die Callback-Funktion auf.

          @michl75 sagte in Skript - JS-Funktion und SQL Abfrage - Ergebnis undifined:

          Der Ansatz besser?

          Nein, denn so hat die Callback-Funktion den Namen ergebnis(result), wird aber dennoch erst aufgerufen, wenn sendTo() abgearbeitet ist.

          Verwende das Blockly-sendTo, denn dann kann innerhalb der Callback-Funktion das Ergebnis ausgewertet werden.

          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

          1 Antwort Letzte Antwort
          0
          • michl75M Offline
            michl75M Offline
            michl75
            schrieb am zuletzt editiert von
            #5

            @paul53 ah ok, also es wartet nicht ab... ok, wäre es besser wenn ich nicht blockly nehme dann?

            Ich habs mal versucht so umzusetzen... Ergebnis ist nun aber "leer"...

            io1.PNG

            paul53P 1 Antwort Letzte Antwort
            0
            • michl75M michl75

              @paul53 ah ok, also es wartet nicht ab... ok, wäre es besser wenn ich nicht blockly nehme dann?

              Ich habs mal versucht so umzusetzen... Ergebnis ist nun aber "leer"...

              io1.PNG

              paul53P Offline
              paul53P Offline
              paul53
              schrieb am zuletzt editiert von paul53
              #6

              @michl75
              Wie man mit dem Blockly-sendTo eine query-Abfrage macht, weiß ich auch nicht. Das Ergebnis steht jedenfalls nicht in Wert, sondern in einer Variable result.

              Versuche es mal so:

              Bild_2021-03-06_115212.png

              Funktion abfrage(t):

              let _sql = "SELECT AVG(val) FROM iobroker.ts_number where id = 218 and ts > (" + t + ")";
              sendTo('sql.0', 'query', _sql, auswertung);
              

              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

              michl75M 1 Antwort Letzte Antwort
              0
              • paul53P paul53

                @michl75
                Wie man mit dem Blockly-sendTo eine query-Abfrage macht, weiß ich auch nicht. Das Ergebnis steht jedenfalls nicht in Wert, sondern in einer Variable result.

                Versuche es mal so:

                Bild_2021-03-06_115212.png

                Funktion abfrage(t):

                let _sql = "SELECT AVG(val) FROM iobroker.ts_number where id = 218 and ts > (" + t + ")";
                sendTo('sql.0', 'query', _sql, auswertung);
                
                michl75M Offline
                michl75M Offline
                michl75
                schrieb am zuletzt editiert von michl75
                #7

                @paul53 Erstmal danke für deine Mühe... Habe erst mal meins verworfen und NEU wie deins aufgebaut....

                io1.PNG

                Der Code dazu... genau so...

                let _sql = "SELECT AVG(val) FROM iobroker.ts_number where id = 218 and ts > (" + t + ")";
                sendTo('sql.0', 'query', _sql, auswertung);
                {1}
                

                und Ergebnis:
                io1.PNG

                Hätte ich nur mehr Ahnung davon...

                EDIT .. das Doppelte {1} ... keine ahnugn woher das kommt, steht aber nicht so in meinem Code...

                paul53P 1 Antwort Letzte Antwort
                0
                • michl75M michl75

                  @paul53 Erstmal danke für deine Mühe... Habe erst mal meins verworfen und NEU wie deins aufgebaut....

                  io1.PNG

                  Der Code dazu... genau so...

                  let _sql = "SELECT AVG(val) FROM iobroker.ts_number where id = 218 and ts > (" + t + ")";
                  sendTo('sql.0', 'query', _sql, auswertung);
                  {1}
                  

                  und Ergebnis:
                  io1.PNG

                  Hätte ich nur mehr Ahnung davon...

                  EDIT .. das Doppelte {1} ... keine ahnugn woher das kommt, steht aber nicht so in meinem Code...

                  paul53P Offline
                  paul53P Offline
                  paul53
                  schrieb am zuletzt editiert von paul53
                  #8

                  @michl75 sagte: Hätte ich nur mehr Ahnung davon...

                  Ich hatte anfangs noch einen Fehler drin, den ich nachträglich korrigiert habe: Die Funktion auswertung(result) muss den Parameter result erhalten.

                  Bild_2021-03-06_120824.png

                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                  michl75M 1 Antwort Letzte Antwort
                  0
                  • paul53P paul53

                    @michl75 sagte: Hätte ich nur mehr Ahnung davon...

                    Ich hatte anfangs noch einen Fehler drin, den ich nachträglich korrigiert habe: Die Funktion auswertung(result) muss den Parameter result erhalten.

                    Bild_2021-03-06_120824.png

                    michl75M Offline
                    michl75M Offline
                    michl75
                    schrieb am zuletzt editiert von michl75
                    #9

                    @paul53 ok moment ich teste

                    EDIT: Es tut sich was auch wenn noch kein Ergebnis... aber ... so sieht die Ausgabe nun aus:
                    io1.PNG

                    ...und so versucht er es auch mit setState in die Variable zu schreiben - klar bleibt 0 ist ja text und keine Zahl

                    paul53P 1 Antwort Letzte Antwort
                    0
                    • michl75M michl75

                      @paul53 ok moment ich teste

                      EDIT: Es tut sich was auch wenn noch kein Ergebnis... aber ... so sieht die Ausgabe nun aus:
                      io1.PNG

                      ...und so versucht er es auch mit setState in die Variable zu schreiben - klar bleibt 0 ist ja text und keine Zahl

                      paul53P Offline
                      paul53P Offline
                      paul53
                      schrieb am zuletzt editiert von paul53
                      #10

                      @michl75 sagte:

                      so sieht die Ausgabe nun aus:

                      Das sieht schon gut aus. Mach mal weiter:

                      Bild_2021-03-06_122115.png

                      Nun müsste noch obj['AVG(val)'] ermittelt werden, was wohl so wegen der Klammern in Blockly nicht funktioniert.

                      Dann besser gleich eine JS-Funktion mit Ergebnis:

                      return res.result[0]['AVG(val)'];
                      

                      Blockly_temp.JPG

                      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                      michl75M 1 Antwort Letzte Antwort
                      0
                      • paul53P paul53

                        @michl75 sagte:

                        so sieht die Ausgabe nun aus:

                        Das sieht schon gut aus. Mach mal weiter:

                        Bild_2021-03-06_122115.png

                        Nun müsste noch obj['AVG(val)'] ermittelt werden, was wohl so wegen der Klammern in Blockly nicht funktioniert.

                        Dann besser gleich eine JS-Funktion mit Ergebnis:

                        return res.result[0]['AVG(val)'];
                        

                        Blockly_temp.JPG

                        michl75M Offline
                        michl75M Offline
                        michl75
                        schrieb am zuletzt editiert von
                        #11

                        @paul53 sieht nun so aus...
                        io1.PNG

                        glaub wir kommen dem ergebnis näher :)
                        das AVG muss noch weg iwie

                        paul53P 2 Antworten Letzte Antwort
                        0
                        • michl75M michl75

                          @paul53 sieht nun so aus...
                          io1.PNG

                          glaub wir kommen dem ergebnis näher :)
                          das AVG muss noch weg iwie

                          paul53P Offline
                          paul53P Offline
                          paul53
                          schrieb am zuletzt editiert von
                          #12

                          @michl75 sagte in Skript - JS-Funktion und SQL Abfrage - Ergebnis undifined:

                          das AVG muss noch weg

                          Das Problem sind die Klammern (unzulässige Zeichen).

                          Blockly_temp.JPG

                          Funktion average(res):

                          return res.result[0]['AVG(val)'];
                          

                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                          1 Antwort Letzte Antwort
                          0
                          • michl75M michl75

                            @paul53 sieht nun so aus...
                            io1.PNG

                            glaub wir kommen dem ergebnis näher :)
                            das AVG muss noch weg iwie

                            paul53P Offline
                            paul53P Offline
                            paul53
                            schrieb am zuletzt editiert von paul53
                            #13

                            @michl75
                            Man kann die Aufschlüsselung des Abfrageergebnisses auch gleich in die Funktion abfrage(t) packen:

                            let _sql = "SELECT AVG(val) FROM iobroker.ts_number where id = 218 and ts > (" + t + ")";
                            sendTo('sql.0', 'query', _sql, function(res) {
                                if(!res.error) auswertung(res.result[0]['AVG(val)']);
                            });
                            

                            Blockly_temp.JPG

                            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                            michl75M 1 Antwort Letzte Antwort
                            0
                            • paul53P paul53

                              @michl75
                              Man kann die Aufschlüsselung des Abfrageergebnisses auch gleich in die Funktion abfrage(t) packen:

                              let _sql = "SELECT AVG(val) FROM iobroker.ts_number where id = 218 and ts > (" + t + ")";
                              sendTo('sql.0', 'query', _sql, function(res) {
                                  if(!res.error) auswertung(res.result[0]['AVG(val)']);
                              });
                              

                              Blockly_temp.JPG

                              michl75M Offline
                              michl75M Offline
                              michl75
                              schrieb am zuletzt editiert von michl75
                              #14

                              @paul53 SUPER ... vielen herzlichen Dank!!! Es funktioniert!!!

                              vielen herzlichen Dank !!!

                              io1.PNG

                              [gelöst]

                              paul53P 1 Antwort Letzte Antwort
                              0
                              • michl75M michl75

                                @paul53 SUPER ... vielen herzlichen Dank!!! Es funktioniert!!!

                                vielen herzlichen Dank !!!

                                io1.PNG

                                [gelöst]

                                paul53P Offline
                                paul53P Offline
                                paul53
                                schrieb am zuletzt editiert von
                                #15

                                @michl75 sagte: Es funktioniert!!!

                                Die Konvertierung "nach Zahl" sollte nicht erforderlich sein.
                                Markiere bitte das Thema in der Überschrift des ersten Beitrags als [gelöst].

                                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                1 Antwort Letzte Antwort
                                0
                                Antworten
                                • In einem neuen Thema antworten
                                Anmelden zum Antworten
                                • Älteste zuerst
                                • Neuste zuerst
                                • Meiste Stimmen


                                Support us

                                ioBroker
                                Community Adapters
                                Donate

                                552

                                Online

                                32.7k

                                Benutzer

                                82.5k

                                Themen

                                1.3m

                                Beiträge
                                Community
                                Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                ioBroker Community 2014-2025
                                logo
                                • Anmelden

                                • Du hast noch kein Konto? Registrieren

                                • Anmelden oder registrieren, um zu suchen
                                • Erster Beitrag
                                  Letzter Beitrag
                                0
                                • Home
                                • Aktuell
                                • Tags
                                • Ungelesen 0
                                • Kategorien
                                • Unreplied
                                • Beliebt
                                • GitHub
                                • Docu
                                • Hilfe