Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. Zeitstemlel von SQL- Historyeintrag manipulieren

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

Zeitstemlel von SQL- Historyeintrag manipulieren

Scheduled Pinned Locked Moved ioBroker Allgemein
29 Posts 5 Posters 2.5k Views 4 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • F Offline
    F Offline
    Friedel
    wrote on last edited by Friedel
    #20

    @oliverio

    Ich komme hier einfach nicht weiter.
    Den letzten Eintrag anzeigen zu lassen klappt schon nicht.

    Wahrscheinlich ist es nur eine Kleinigkeit, aber ich habe mich hier festgefahren.
    Vieleicht kann mir noch einer auf die Sprünge helfen.

    Bildschirmfoto vom 2025-03-24 20-10-37.png

    javascript.0	20:18:57.377	info	script.js.common.SQL_Datenbank.Zeitstempel_1: sendTo(instance=sql.0, cmd=query, msg="SELECT * FROM daten_iobroker.ts_number WHERE id = '0_userdata.0.Test_SQL.PV_Ertrag_Stunde' ORDER BY ts DESC LIMIT 1;", hasCallback=true)
    javascript.0	20:18:57.377	info	script.js.common.SQL_Datenbank.Zeitstempel_1: sendTo[custom] sql.0: SELECT * FROM daten_iobroker.ts_number WHERE id = '0_userdata.0.Test_SQL.PV_Ertrag_Stunde' ORDER BY ts DESC LIMIT 1;
    javascript.0	20:18:57.378	info	script.js.common.SQL_Datenbank.Zeitstempel_1: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
    javascript.0	20:18:57.386	info	script.js.common.SQL_Datenbank.Zeitstempel_1: { error: null, result: [] }
    
    OliverIOO 1 Reply Last reply
    0
    • F Friedel

      @oliverio

      Ich komme hier einfach nicht weiter.
      Den letzten Eintrag anzeigen zu lassen klappt schon nicht.

      Wahrscheinlich ist es nur eine Kleinigkeit, aber ich habe mich hier festgefahren.
      Vieleicht kann mir noch einer auf die Sprünge helfen.

      Bildschirmfoto vom 2025-03-24 20-10-37.png

      javascript.0	20:18:57.377	info	script.js.common.SQL_Datenbank.Zeitstempel_1: sendTo(instance=sql.0, cmd=query, msg="SELECT * FROM daten_iobroker.ts_number WHERE id = '0_userdata.0.Test_SQL.PV_Ertrag_Stunde' ORDER BY ts DESC LIMIT 1;", hasCallback=true)
      javascript.0	20:18:57.377	info	script.js.common.SQL_Datenbank.Zeitstempel_1: sendTo[custom] sql.0: SELECT * FROM daten_iobroker.ts_number WHERE id = '0_userdata.0.Test_SQL.PV_Ertrag_Stunde' ORDER BY ts DESC LIMIT 1;
      javascript.0	20:18:57.378	info	script.js.common.SQL_Datenbank.Zeitstempel_1: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
      javascript.0	20:18:57.386	info	script.js.common.SQL_Datenbank.Zeitstempel_1: { error: null, result: [] }
      
      OliverIOO Offline
      OliverIOO Offline
      OliverIO
      wrote on last edited by
      #21

      hatte ich ja oben schon geschrieben

      @oliverio sagte in Zeitstemlel von SQL- Historyeintrag manipulieren:

      das problem ist, das der datenpunktname nicht direkt in der tabelle drin steht, sondern auf 2 tabellen aufgeteilt ist. eine tabelle mit den datenpunktnamen und einer id und dann je nach datentyp eine tabelle mit den werten, die aber nur auf die id der datenpunkt tabelle referenziert.
      daher muss man immer noch einen join machen.

      in der tabelle ts_numer ist die spalte id eine nummer. das mapping von id zu datenpunktname erfolgt in der tabelle datapoints. daher muss man ein join machen.

      du hast 2 möglichkeiten
      a) auswahl über den datenpunktnamen wie folgt:

      SELECT tn.* 
      FROM ts_number tn 
      JOIN datapoints dp 
      ON dp.id = tn.id 
      WHERE dp.name = 'datenpunkt id' 
      ORDER BY tn.ts DESC 
      LIMIT 1 
      

      oder b)
      du suchst in tabelle datapoint die id passend zu deinem datenpunkt heraus (wie gesagt das ist eine nummer)

      dann kannst du auch so machen. 123 dann gegen die eigentliche id austauschen

      SELECT * 
      FROM daten_iobroker.ts_number 
      WHERE id = 123 
      ORDER BY ts DESC 
      LIMIT 1
      

      Meine Adapter und Widgets
      TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
      Links im Profil

      1 Reply Last reply
      0
      • F Offline
        F Offline
        Friedel
        wrote on last edited by
        #22

        @oliverio

        Hallo, habe es jetzt hinbekommen so wie Du es geasgt hattest.

        Hier einmal die Abfrage nach dem letzten Eintrag.

        sendTo('sql.0', 'query', 'SELECT * FROM daten_iobroker.ts_number WHERE id = 33 ORDER BY ts DESC LIMIT 1', async (result) => {
            console.info(result);
        });
        

        Und hier einmal wo der Zeitstempel vom letzten Eintrag geändert wird.

        sendTo('sql.0', 'query', 'UPDATE daten_iobroker.ts_number SET ts = \'1743082140098\' WHERE id = 33 ORDER BY ts DESC LIMIT 1');
        

        Nun würde ich aber gerne die ID und den Zeitstempel als Variable übergeben. Dieses bekomme ich aber nicht hin.

        Kann mir hier noch einer weiterhelfen?

        F 1 Reply Last reply
        0
        • F Friedel

          @oliverio

          Hallo, habe es jetzt hinbekommen so wie Du es geasgt hattest.

          Hier einmal die Abfrage nach dem letzten Eintrag.

          sendTo('sql.0', 'query', 'SELECT * FROM daten_iobroker.ts_number WHERE id = 33 ORDER BY ts DESC LIMIT 1', async (result) => {
              console.info(result);
          });
          

          Und hier einmal wo der Zeitstempel vom letzten Eintrag geändert wird.

          sendTo('sql.0', 'query', 'UPDATE daten_iobroker.ts_number SET ts = \'1743082140098\' WHERE id = 33 ORDER BY ts DESC LIMIT 1');
          

          Nun würde ich aber gerne die ID und den Zeitstempel als Variable übergeben. Dieses bekomme ich aber nicht hin.

          Kann mir hier noch einer weiterhelfen?

          F Offline
          F Offline
          Friedel
          wrote on last edited by
          #23

          @friedel sagte in Zeitstemlel von SQL- Historyeintrag manipulieren:

          @oliverio

          Hallo, habe es jetzt hinbekommen so wie Du es geasgt hattest.

          Hier einmal die Abfrage nach dem letzten Eintrag.

          sendTo('sql.0', 'query', 'SELECT * FROM daten_iobroker.ts_number WHERE id = 33 ORDER BY ts DESC LIMIT 1', async (result) => {
              console.info(result);
          });
          

          Und hier einmal wo der Zeitstempel vom letzten Eintrag geändert wird.

          sendTo('sql.0', 'query', 'UPDATE daten_iobroker.ts_number SET ts = \'1743082140098\' WHERE id = 33 ORDER BY ts DESC LIMIT 1');
          

          Nun würde ich aber gerne die ID und den Zeitstempel als Variable übergeben. Dieses bekomme ich aber nicht hin.

          Kann mir hier noch einer weiterhelfen?

          Bildschirmfoto vom 2025-03-28 19-51-00.png

          1 Reply Last reply
          0
          • F Offline
            F Offline
            Friedel
            wrote on last edited by
            #24

            @friedel
            Die Frage ist wie ich die Variabel übergeben muss?

            var Datenpunkt = _id;
            var Timestamp = _ts;
            
            sendTo('sql.0', 'query', 'SELECT * FROM daten_iobroker.ts_number WHERE id == Datenpunkt ORDER BY ts DESC LIMIT 1', async (result) => {
                console.info(result);
            });
            
            console.log(Datenpunkt);
            console.log(Timestamp);
            
            
            OliverIOO 1 Reply Last reply
            0
            • F Friedel

              @friedel
              Die Frage ist wie ich die Variabel übergeben muss?

              var Datenpunkt = _id;
              var Timestamp = _ts;
              
              sendTo('sql.0', 'query', 'SELECT * FROM daten_iobroker.ts_number WHERE id == Datenpunkt ORDER BY ts DESC LIMIT 1', async (result) => {
                  console.info(result);
              });
              
              console.log(Datenpunkt);
              console.log(Timestamp);
              
              
              OliverIOO Offline
              OliverIOO Offline
              OliverIO
              wrote on last edited by OliverIO
              #25

              @friedel

              Der SQL Befehl wird als Text übergeben.
              Wenn du da variablen einbauen willst, musst du einen Textring so zusammenbauen, dass die variablen dort eingefügt werden.
              Am besten geht das mit einem so genannten Template String
              https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals

              Meine Adapter und Widgets
              TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
              Links im Profil

              F 1 Reply Last reply
              0
              • OliverIOO OliverIO

                @friedel

                Der SQL Befehl wird als Text übergeben.
                Wenn du da variablen einbauen willst, musst du einen Textring so zusammenbauen, dass die variablen dort eingefügt werden.
                Am besten geht das mit einem so genannten Template String
                https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals

                F Offline
                F Offline
                Friedel
                wrote on last edited by
                #26

                @oliverio
                Ich komme immer etwas weiter :blush:

                var Datenpunkt = _id;
                var Timestamp = _ts;
                
                var sqlQuery_1 = "SELECT * FROM daten_iobroker.ts_number WHERE id = " + Datenpunkt;
                var sqlQuery_2 = "ORDER BY ts DESC LIMIT 1";
                
                console.log(sqlQuery_1);
                console.log(sqlQuery_2);
                
                sendTo('sql.0', 'query', sqlQuery_1, sqlQuery_2, async (result) => {
                    console.info(result);
                });
                

                Aber noch eine Fehlermeldung obwohl der Befehl doch jetzt passen müsste.

                javascript.0	16:49:37.930	info	Start JavaScript script.js.common.SQL_Datenbank.AAAA (Blockly)
                javascript.0	16:49:37.957	info	script.js.common.SQL_Datenbank.AAAA: SELECT * FROM daten_iobroker.ts_number WHERE id = 33
                javascript.0	16:49:37.958	info	script.js.common.SQL_Datenbank.AAAA: ORDER BY ts DESC LIMIT 1
                javascript.0	16:49:37.959	error	script.js.common.SQL_Datenbank.AAAA: Error: Parameter "options" needs to be a real object but type "string" has been passed
                javascript.0	16:49:37.960	error	at etwas_tun (script.js.common.SQL_Datenbank.AAAA:40:5)
                javascript.0	16:49:37.960	error	at script.js.common.SQL_Datenbank.AAAA:64:7
                javascript.0	16:49:37.960	error	at script.js.common.SQL_Datenbank.AAAA:78:3
                
                OliverIOO 1 Reply Last reply
                0
                • F Friedel

                  @oliverio
                  Ich komme immer etwas weiter :blush:

                  var Datenpunkt = _id;
                  var Timestamp = _ts;
                  
                  var sqlQuery_1 = "SELECT * FROM daten_iobroker.ts_number WHERE id = " + Datenpunkt;
                  var sqlQuery_2 = "ORDER BY ts DESC LIMIT 1";
                  
                  console.log(sqlQuery_1);
                  console.log(sqlQuery_2);
                  
                  sendTo('sql.0', 'query', sqlQuery_1, sqlQuery_2, async (result) => {
                      console.info(result);
                  });
                  

                  Aber noch eine Fehlermeldung obwohl der Befehl doch jetzt passen müsste.

                  javascript.0	16:49:37.930	info	Start JavaScript script.js.common.SQL_Datenbank.AAAA (Blockly)
                  javascript.0	16:49:37.957	info	script.js.common.SQL_Datenbank.AAAA: SELECT * FROM daten_iobroker.ts_number WHERE id = 33
                  javascript.0	16:49:37.958	info	script.js.common.SQL_Datenbank.AAAA: ORDER BY ts DESC LIMIT 1
                  javascript.0	16:49:37.959	error	script.js.common.SQL_Datenbank.AAAA: Error: Parameter "options" needs to be a real object but type "string" has been passed
                  javascript.0	16:49:37.960	error	at etwas_tun (script.js.common.SQL_Datenbank.AAAA:40:5)
                  javascript.0	16:49:37.960	error	at script.js.common.SQL_Datenbank.AAAA:64:7
                  javascript.0	16:49:37.960	error	at script.js.common.SQL_Datenbank.AAAA:78:3
                  
                  OliverIOO Offline
                  OliverIOO Offline
                  OliverIO
                  wrote on last edited by
                  #27

                  @friedel

                  Die Parameter haben eine feste Reihenfolge
                  Du hast jetzt

                  Meine Adapter und Widgets
                  TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                  Links im Profil

                  OliverIOO 1 Reply Last reply
                  0
                  • OliverIOO OliverIO

                    @friedel

                    Die Parameter haben eine feste Reihenfolge
                    Du hast jetzt

                    OliverIOO Offline
                    OliverIOO Offline
                    OliverIO
                    wrote on last edited by
                    #28

                    @oliverio

                    Die Parameter haben alle eine feste Reihenfolge.
                    Du hast jetzt einfach, an der Stelle, wo der Befehl ein optionales Objekt mit Optionen erwartet.
                    sqlQuery_2 Reingeschrieben. Das meckert er an.
                    du willst aber einfach nur einen einzigen String übergeben.

                    Ich habe jetzt aus dem Komma einfach ein Plus gemacht, das sorgt für eine String Verkettung
                    Beachte bitte auch, dass zusätzliche Leerzeichen vor ORDER.
                    das sorgt dafür, dass zwischen deinem Datenpunkt wird und dem nächsten Befehl Order eine Trennung stattfindet.
                    Auch benötigst du eigentlich diese Aufteilung in zwei variablen nicht, da man bei SQL alles hintereinander schreiben kann. Sogar mehrere Befehle kann man mit Strichpunkt trennen.

                    var Datenpunkt = _id;
                    var Timestamp = _ts;
                     
                    var sqlQuery_1 = "SELECT * FROM daten_iobroker.ts_number WHERE id = " + Datenpunkt;
                    var sqlQuery_2 = " ORDER BY ts DESC LIMIT 1";
                     
                    console.log(sqlQuery_1);
                    console.log(sqlQuery_2);
                     
                    sendTo('sql.0', 'query', sqlQuery_1 + sqlQuery_2, async (result) => {
                        console.info(result);
                    });
                    
                    

                    Meine Adapter und Widgets
                    TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                    Links im Profil

                    F 1 Reply Last reply
                    0
                    • OliverIOO OliverIO

                      @oliverio

                      Die Parameter haben alle eine feste Reihenfolge.
                      Du hast jetzt einfach, an der Stelle, wo der Befehl ein optionales Objekt mit Optionen erwartet.
                      sqlQuery_2 Reingeschrieben. Das meckert er an.
                      du willst aber einfach nur einen einzigen String übergeben.

                      Ich habe jetzt aus dem Komma einfach ein Plus gemacht, das sorgt für eine String Verkettung
                      Beachte bitte auch, dass zusätzliche Leerzeichen vor ORDER.
                      das sorgt dafür, dass zwischen deinem Datenpunkt wird und dem nächsten Befehl Order eine Trennung stattfindet.
                      Auch benötigst du eigentlich diese Aufteilung in zwei variablen nicht, da man bei SQL alles hintereinander schreiben kann. Sogar mehrere Befehle kann man mit Strichpunkt trennen.

                      var Datenpunkt = _id;
                      var Timestamp = _ts;
                       
                      var sqlQuery_1 = "SELECT * FROM daten_iobroker.ts_number WHERE id = " + Datenpunkt;
                      var sqlQuery_2 = " ORDER BY ts DESC LIMIT 1";
                       
                      console.log(sqlQuery_1);
                      console.log(sqlQuery_2);
                       
                      sendTo('sql.0', 'query', sqlQuery_1 + sqlQuery_2, async (result) => {
                          console.info(result);
                      });
                      
                      
                      F Offline
                      F Offline
                      Friedel
                      wrote on last edited by
                      #29

                      @oliverio
                      Oh man, was soll ich sagen, es funktioniert. :+1: :blush:
                      Vielen vielen Dank für deine Unterstützung. :+1:

                      1 Reply Last reply
                      0
                      Reply
                      • Reply as topic
                      Log in to reply
                      • Oldest to Newest
                      • Newest to Oldest
                      • Most Votes


                      Support us

                      ioBroker
                      Community Adapters
                      Donate
                      FAQ Cloud / IOT
                      HowTo: Node.js-Update
                      HowTo: Backup/Restore
                      Downloads
                      BLOG

                      223

                      Online

                      32.7k

                      Users

                      82.3k

                      Topics

                      1.3m

                      Posts
                      Community
                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                      ioBroker Community 2014-2025
                      logo
                      • Login

                      • Don't have an account? Register

                      • Login or register to search.
                      • First post
                        Last post
                      0
                      • Home
                      • Recent
                      • Tags
                      • Unread 0
                      • Categories
                      • Unreplied
                      • Popular
                      • GitHub
                      • Docu
                      • Hilfe