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. ioBroker Allgemein
  4. Zeitstemlel von SQL- Historyeintrag manipulieren

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    18
    1
    686

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.0k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.3k

Zeitstemlel von SQL- Historyeintrag manipulieren

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
29 Beiträge 5 Kommentatoren 2.3k Aufrufe 4 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.
  • David G.D David G.

    @bananajoe

    Hab das Skript jetzt mal getestet und in ein Blockly gepackt.

    Klappt bestens.

    Screenshot_20230122_175238_Chrome.jpg

    <xml xmlns="https://developers.google.com/blockly/xml">
      <variables>
        <variable id="Civ)@a`PPOAP;Au`yrk7">id</variable>
        <variable id="He?L*;%S5ZxhQdVQ|nwK">value</variable>
        <variable id="}H`Md*ym;;=9MQYQ+d#g">ts</variable>
        <variable id="}FYTizs{~u7qb%G~dwNB">ack</variable>
        <variable id="mbSwYNv,Ng@m[=[1wvlp">from</variable>
        <variable id="n]Oh`3dmP!HF^Id)E2cC">q</variable>
      </variables>
      <block type="procedures_defcustomnoreturn" id="byaN9|n~rP|LoWSf8_V~" x="-187" y="-838">
        <mutation statements="false">
          <arg name="id" varid="Civ)@a`PPOAP;Au`yrk7"></arg>
          <arg name="value" varid="He?L*;%S5ZxhQdVQ|nwK"></arg>
          <arg name="ts" varid="}H`Md*ym;;=9MQYQ+d#g"></arg>
          <arg name="ack" varid="}FYTizs{~u7qb%G~dwNB"></arg>
          <arg name="from" varid="mbSwYNv,Ng@m[=[1wvlp"></arg>
          <arg name="q" varid="n]Oh`3dmP!HF^Id)E2cC"></arg>
        </mutation>
        <field name="NAME">Sql</field>
        <field name="SCRIPT">ewogICAgbGV0IHN0YXRlbWVudCA9IGAKICAgICAgICBSRVBMQUNFIElOVE8gaW9icm9rZXIudHNfbnVtYmVyIAogICAgICAgICAgICAoaWQsIHRzLCB2YWwsIGFjaywgX2Zyb20sIHEpIAogICAgICAgICAgICBWQUxVRVMgKChTRUxFQ1QgaWQgRlJPTSBpb2Jyb2tlci5kYXRhcG9pbnRzIFdIRVJFIG5hbWUgPSAiJHtpZH0iKSwgJHt0c30sICR7dmFsdWV9LCAke2Fja30sICR7ZnJvbX0sICR7cX0pCiAgICBgCiAgICAKICAgIHNlbmRUbygic3FsLjAiLCAicXVlcnkiLCBzdGF0ZW1lbnQsIGUgPT4gewogICAgICAgIGlmIChlICYmIGUuZXJyb3IpIHsKICAgICAgICAgICAgbG9nKGUuZXJyb3IpCiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgLy8gbG9nKCJEb25lISIpCiAgICAgICAgfQogICAgfSkKfQo=</field>
        <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
      </block>
      <block type="procedures_callcustomnoreturn" id="KIg}!gS-U_Q,4VS(Y;ag" x="-187" y="-787">
        <mutation name="Sql">
          <arg name="id"></arg>
          <arg name="value"></arg>
          <arg name="ts"></arg>
          <arg name="ack"></arg>
          <arg name="from"></arg>
          <arg name="q"></arg>
        </mutation>
        <value name="ARG0">
          <block type="text" id="DxgSLx$~EyIX~8JHOLN!">
            <field name="TEXT">0_userdata.0.sqlnummer</field>
          </block>
        </value>
        <value name="ARG1">
          <block type="math_number" id="VwIr0SM1gpzH}fLap/,5">
            <field name="NUM">9</field>
          </block>
        </value>
        <value name="ARG2">
          <block type="time_get" id="v8^^Zqii`2`lnLSSwwpz">
            <mutation xmlns="http://www.w3.org/1999/xhtml" format="false" language="false"></mutation>
            <field name="OPTION">object</field>
          </block>
        </value>
        <value name="ARG3">
          <block type="math_number" id="9$_Ioh[7,!JS0{?tgRI+">
            <field name="NUM">1</field>
          </block>
        </value>
        <value name="ARG4">
          <block type="math_number" id="24j,lq_?zyj-~=}ej%@,">
            <field name="NUM">1</field>
          </block>
        </value>
        <value name="ARG5">
          <block type="math_number" id="J{v_.^f0|TOmC)1c3!QP">
            <field name="NUM">0</field>
          </block>
        </value>
      </block>
    </xml>
    
    F Offline
    F Offline
    Friedel
    schrieb am zuletzt editiert von
    #6

    @david-g Hallo,
    ich möchte dieses Thema gerne wieder aufgreifen.
    Ich würde gerne bei dem letzten Eintrag in der SQL Datenbank den Zeitstempel nachträglich ändern.
    Habe es mit dem Hinweis von @liv-in-sky versucht, bekomme es aber nicht hin.
    Bin auch eher die Fraktion Blockly und habe es in einer Javascript-Funktion eingetragen um diese dann bei Bedarf aufzurufen.
    Bei dem Aufruf würde ich gerne den Datenpunkt und den neuen Zeitstempel übergeben.
    Kann mir hier einer weiterhelfen?

    BananaJoeB 1 Antwort Letzte Antwort
    0
    • F Friedel

      @david-g Hallo,
      ich möchte dieses Thema gerne wieder aufgreifen.
      Ich würde gerne bei dem letzten Eintrag in der SQL Datenbank den Zeitstempel nachträglich ändern.
      Habe es mit dem Hinweis von @liv-in-sky versucht, bekomme es aber nicht hin.
      Bin auch eher die Fraktion Blockly und habe es in einer Javascript-Funktion eingetragen um diese dann bei Bedarf aufzurufen.
      Bei dem Aufruf würde ich gerne den Datenpunkt und den neuen Zeitstempel übergeben.
      Kann mir hier einer weiterhelfen?

      BananaJoeB Online
      BananaJoeB Online
      BananaJoe
      Most Active
      schrieb am zuletzt editiert von
      #7

      @friedel sagte in Zeitstemlel von SQL- Historyeintrag manipulieren:

      Ich würde gerne bei dem letzten Eintrag in der SQL Datenbank den Zeitstempel nachträglich ändern.

      du kannst den löschen und neu mit dem richtigen Wert anlegen (Reihenfolge beliebig).
      Im Idealfall schreibst du den falschen Eintrag gar nicht erst

      ioBroker@Ubuntu 24.04 LTS (VMware) für: >260 Geräte, 5 Switche, 7 AP, 9 IP-Cam, 1 NAS 42TB, 1 ESXi 15TB, 4 Proxmox 1TB, 1 Hyper-V 48TB, 14 x Echo, 5x FireTV, 5 x Tablett/Handy VIS || >=160 Tasmota/Shelly || >=95 ZigBee || PV 8.1kW / Akku 14kWh || 2x USV 750W kaskadiert || Creality CR-10 SE 3D-Drucker

      F 1 Antwort Letzte Antwort
      0
      • BananaJoeB BananaJoe

        @friedel sagte in Zeitstemlel von SQL- Historyeintrag manipulieren:

        Ich würde gerne bei dem letzten Eintrag in der SQL Datenbank den Zeitstempel nachträglich ändern.

        du kannst den löschen und neu mit dem richtigen Wert anlegen (Reihenfolge beliebig).
        Im Idealfall schreibst du den falschen Eintrag gar nicht erst

        F Offline
        F Offline
        Friedel
        schrieb am zuletzt editiert von
        #8

        @bananajoe
        Der Eintrag wird automatisch geschrieben. das möchte ich auch gerne so lassen.
        Bei einer bestimmten Bedingung (Trigger) soll der Zeitstempel geändert werden.
        Das braucht auch nur für den letzten Datensatz gemacht werden.

        BananaJoeB OliverIOO 2 Antworten Letzte Antwort
        0
        • F Friedel

          @bananajoe
          Der Eintrag wird automatisch geschrieben. das möchte ich auch gerne so lassen.
          Bei einer bestimmten Bedingung (Trigger) soll der Zeitstempel geändert werden.
          Das braucht auch nur für den letzten Datensatz gemacht werden.

          BananaJoeB Online
          BananaJoeB Online
          BananaJoe
          Most Active
          schrieb am zuletzt editiert von
          #9

          @friedel dann mit dem richtige Zeitstempel noch mal neu schreiben und den falschen löschen.
          Liegt der "richtige" davor oder dahinter?

          ioBroker@Ubuntu 24.04 LTS (VMware) für: >260 Geräte, 5 Switche, 7 AP, 9 IP-Cam, 1 NAS 42TB, 1 ESXi 15TB, 4 Proxmox 1TB, 1 Hyper-V 48TB, 14 x Echo, 5x FireTV, 5 x Tablett/Handy VIS || >=160 Tasmota/Shelly || >=95 ZigBee || PV 8.1kW / Akku 14kWh || 2x USV 750W kaskadiert || Creality CR-10 SE 3D-Drucker

          F 1 Antwort Letzte Antwort
          0
          • F Friedel

            @bananajoe
            Der Eintrag wird automatisch geschrieben. das möchte ich auch gerne so lassen.
            Bei einer bestimmten Bedingung (Trigger) soll der Zeitstempel geändert werden.
            Das braucht auch nur für den letzten Datensatz gemacht werden.

            OliverIOO Offline
            OliverIOO Offline
            OliverIO
            schrieb am zuletzt editiert von
            #10

            @friedel
            Es dürfte zwar egal sein, aber wenn dann würde ich mit einem Update sql Befehl den Datensatz aktualisieren.
            Wenn du nur den letzten aktualisieren willst, könntest du aber auch einen neuen zusätzlichen Datensatz schreiben.

            Bei Datenbanken gibt es nicht wirklich ein davor und danach, da die Methode wie eine Datenbank dann wirklich physisch speichert für einen Nutzer ziemlich uninteressant ist.
            Die Reihenfolge kommt über eine Sortierung, meist dann nach dem primary key, welcher meist die id ist.

            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 Antwort Letzte Antwort
            0
            • BananaJoeB BananaJoe

              @friedel dann mit dem richtige Zeitstempel noch mal neu schreiben und den falschen löschen.
              Liegt der "richtige" davor oder dahinter?

              F Offline
              F Offline
              Friedel
              schrieb am zuletzt editiert von
              #11

              @bananajoe
              Dein Vorschlag mit neu schreiben funktioniert ja.
              Hat aber den Nachteil das ich den Wert nicht abfragen kann sondern nur für z.B. eChart nutzen kann.
              Ich möchte nur den Zeitstempel des zuletzt eingetragenen Wertes ändern.

              OliverIOO 1 Antwort Letzte Antwort
              0
              • F Friedel

                @bananajoe
                Dein Vorschlag mit neu schreiben funktioniert ja.
                Hat aber den Nachteil das ich den Wert nicht abfragen kann sondern nur für z.B. eChart nutzen kann.
                Ich möchte nur den Zeitstempel des zuletzt eingetragenen Wertes ändern.

                OliverIOO Offline
                OliverIOO Offline
                OliverIO
                schrieb am zuletzt editiert von
                #12

                @friedel

                Kein Problem. Dann einfach ein updatestatement mit einer where clause auf den datenpunkt id und dann einfach die max funktion auf die id oder den timestamp mit Limit 1 ausführen. Schon hast du den letzten Datensatz zu deinem datenpunkt.

                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 Antwort Letzte Antwort
                0
                • OliverIOO OliverIO

                  @friedel
                  Es dürfte zwar egal sein, aber wenn dann würde ich mit einem Update sql Befehl den Datensatz aktualisieren.
                  Wenn du nur den letzten aktualisieren willst, könntest du aber auch einen neuen zusätzlichen Datensatz schreiben.

                  Bei Datenbanken gibt es nicht wirklich ein davor und danach, da die Methode wie eine Datenbank dann wirklich physisch speichert für einen Nutzer ziemlich uninteressant ist.
                  Die Reihenfolge kommt über eine Sortierung, meist dann nach dem primary key, welcher meist die id ist.

                  F Offline
                  F Offline
                  Friedel
                  schrieb am zuletzt editiert von
                  #13

                  @oliverio
                  Mit Update habe ich es probiert, aber ich bin ganz ehrlich ich tue mich mit Javascript etwas schwer.
                  Würde es gerne in ein Blockly Javascriptfunktion mit Parameter packen und dann über Blockly ausführen.

                  OliverIOO 1 Antwort Letzte Antwort
                  0
                  • F Friedel

                    @oliverio
                    Mit Update habe ich es probiert, aber ich bin ganz ehrlich ich tue mich mit Javascript etwas schwer.
                    Würde es gerne in ein Blockly Javascriptfunktion mit Parameter packen und dann über Blockly ausführen.

                    OliverIOO Offline
                    OliverIOO Offline
                    OliverIO
                    schrieb am zuletzt editiert von OliverIO
                    #14

                    @friedel

                    Wieso JavaScript? Ich würde das direkt mit sql machen. ok, ein wenig javascript ist auch dabei. mit blockly kenne ich mich leider nicht so gut aus

                    ergänzung:

                    hier das sql für den abruf des letzten eintrags anhand des datenpunktnamens.

                    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
                    

                    und hier der befehl zum aktualisieren

                    UPDATE ts_number
                    SET ts= 1742833899865
                    WHERE id = (
                        SELECT dp.id
                        FROM datapoints dp
                        WHERE dp.name = 'datenpunkt id'
                    )
                    AND ts = (
                        SELECT MAX(tn.ts)
                        FROM ts_number tn
                        JOIN datapoints dp ON dp.id = tn.id
                        WHERE dp.name = 'datenpunkt id'
                    );
                    

                    ggfs muss bei den FROM noch jeweils der Datenbankname davor geschrieben werden.
                    Also anhand eines Beispiels:

                    FROM ts_number

                    nach

                    FROM iobroker.ts_number

                    falls die Datenbank iobroker heißt

                    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 Antwort Letzte Antwort
                    0
                    • F Offline
                      F Offline
                      Friedel
                      schrieb am zuletzt editiert von
                      #15

                      @oliverio
                      Dieses ist mein Versuch. Aber er meldet direkt Fehler.

                      UPDATE daten_iobroker.ts_number SET ts = '1742832000000' WHERE id = 0_userdata.0.Test_SQL.PV_Ertrag_Stunde ORDER BY ts DESC LIMIT 1;
                      
                      OliverIOO 2 Antworten Letzte Antwort
                      0
                      • F Friedel

                        @oliverio
                        Dieses ist mein Versuch. Aber er meldet direkt Fehler.

                        UPDATE daten_iobroker.ts_number SET ts = '1742832000000' WHERE id = 0_userdata.0.Test_SQL.PV_Ertrag_Stunde ORDER BY ts DESC LIMIT 1;
                        
                        OliverIOO Offline
                        OliverIOO Offline
                        OliverIO
                        schrieb am zuletzt editiert von OliverIO
                        #16

                        @friedel

                        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.

                        ich kann zwar sql, hab mir aber jetzt nur schnell die mal mit chat gpt erstellen lassen. man muss chatgpt halt die informationen mitliefern wie bspw:

                        ich habe eine tabelle mit datapoints und einer spalte id und name, sowie eine tabelle 
                        ts_number mit den spalten id, welche der id in tabelle datapoints entspricht und einer spalte ts 
                        für einen timestamp, sowie eine spalte value. ich benötige nun ein sql zur abfrage zeitlich 
                        letzten wertes anhand eines datenpunkt namens und ein sql zur aktualisierung des werts
                        
                        

                        als ergebnis hat mit chatgpt sogar eine erklärung geliefert.
                        das kannst du auch zur fehlersuche verwenden.

                        schau dir auch mal den inhalt der datenbank an, die iobroker verwendet.
                        am besten für mysql/mariadb verwendest du myphpadmin. ist mit docker auch relativ schnell installiert

                        ich habe oben das update sql noch angepasst, da ich gemerkt habe das du ja nicht value, sonder ts anpassen willst

                        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 Antwort Letzte Antwort
                        0
                        • F Friedel

                          @oliverio
                          Dieses ist mein Versuch. Aber er meldet direkt Fehler.

                          UPDATE daten_iobroker.ts_number SET ts = '1742832000000' WHERE id = 0_userdata.0.Test_SQL.PV_Ertrag_Stunde ORDER BY ts DESC LIMIT 1;
                          
                          OliverIOO Offline
                          OliverIOO Offline
                          OliverIO
                          schrieb am zuletzt editiert von
                          #17

                          @friedel sagte in Zeitstemlel von SQL- Historyeintrag manipulieren:

                          Aber er meldet direkt Fehler.

                          für bessere hilfe ist es immer gut, die fehler auch gleich mit zu benennen.
                          "er meldet fehler" ist sehr generisch

                          gut hier wusste ich es, aber für die weitere verfolgung bitte so

                          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 Antwort Letzte Antwort
                          0
                          • OliverIOO OliverIO

                            @friedel

                            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.

                            ich kann zwar sql, hab mir aber jetzt nur schnell die mal mit chat gpt erstellen lassen. man muss chatgpt halt die informationen mitliefern wie bspw:

                            ich habe eine tabelle mit datapoints und einer spalte id und name, sowie eine tabelle 
                            ts_number mit den spalten id, welche der id in tabelle datapoints entspricht und einer spalte ts 
                            für einen timestamp, sowie eine spalte value. ich benötige nun ein sql zur abfrage zeitlich 
                            letzten wertes anhand eines datenpunkt namens und ein sql zur aktualisierung des werts
                            
                            

                            als ergebnis hat mit chatgpt sogar eine erklärung geliefert.
                            das kannst du auch zur fehlersuche verwenden.

                            schau dir auch mal den inhalt der datenbank an, die iobroker verwendet.
                            am besten für mysql/mariadb verwendest du myphpadmin. ist mit docker auch relativ schnell installiert

                            ich habe oben das update sql noch angepasst, da ich gemerkt habe das du ja nicht value, sonder ts anpassen willst

                            F Offline
                            F Offline
                            Friedel
                            schrieb am zuletzt editiert von
                            #18

                            @oliverio
                            Danke für die Unterstützung.
                            Ich werde es gleich mal ausprobieren.
                            Mit chat gpt habe ich noch nicht gearbeitet, schau ich mir auch gleich mal an.

                            OliverIOO 1 Antwort Letzte Antwort
                            0
                            • F Friedel

                              @oliverio
                              Danke für die Unterstützung.
                              Ich werde es gleich mal ausprobieren.
                              Mit chat gpt habe ich noch nicht gearbeitet, schau ich mir auch gleich mal an.

                              OliverIOO Offline
                              OliverIOO Offline
                              OliverIO
                              schrieb am zuletzt editiert von
                              #19

                              @friedel
                              gerade für anfänger ist das ideal.
                              auch zum erklären, einfach reinkopieren zeile leer lassen und nach erklärung fragen.
                              alles was mit strikter syntax versehen ist können LLMs sehr gut.
                              Man muss aber alles nochmal checken, aber du kannst mit chatgpt sprechen wie mit einem hilfsprogrammierer. wenn du dann sagst das du anfänger bist, erklärt chatgpt auch mehr,detaillierter und einfacher, so das es anfänger auch verstehen. ansonsten immer nachfragen

                              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 Antwort Letzte Antwort
                              0
                              • F Offline
                                F Offline
                                Friedel
                                schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                                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
                                  schrieb am zuletzt editiert von
                                  #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 Antwort Letzte Antwort
                                  0
                                  • F Offline
                                    F Offline
                                    Friedel
                                    schrieb am zuletzt editiert von
                                    #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 Antwort Letzte Antwort
                                    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
                                      schrieb am zuletzt editiert von
                                      #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 Antwort Letzte Antwort
                                      0
                                      • F Offline
                                        F Offline
                                        Friedel
                                        schrieb am zuletzt editiert von
                                        #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 Antwort Letzte Antwort
                                        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
                                          schrieb am zuletzt editiert von 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 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
                                          FAQ Cloud / IOT
                                          HowTo: Node.js-Update
                                          HowTo: Backup/Restore
                                          Downloads
                                          BLOG

                                          709

                                          Online

                                          32.5k

                                          Benutzer

                                          81.6k

                                          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