Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • 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. History-Adapter (insb. SQL) mit periodischer Datenspeicherung

NEWS

  • Neuer ioBroker-Blog online: Monatsrückblick März/April 2026
    BluefoxB
    Bluefox
    8
    1
    528

  • Verwendung von KI bitte immer deutlich kennzeichnen
    HomoranH
    Homoran
    10
    1
    438

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    1.0k

History-Adapter (insb. SQL) mit periodischer Datenspeicherung

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
17 Beiträge 6 Kommentatoren 2.1k Aufrufe 1 Beobachtet
  • Ä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.
  • paul53P Offline
    paul53P Offline
    paul53
    schrieb am zuletzt editiert von
    #6

    @dtp:

    So richtig rund wäre es übrigens für mich, wenn ich eine feste Uhrzeit vorgeben könnte. Hintergrund ist der, dass ich die Tagesverbrauchswerte erfasse und da ist es sehr vorteilhaft, wenn ich das am Ende eines jeden Tages mache. Mit der aktuellen Lösung muss ich nun erst mal bis 23:59 Uhr aufbleiben, um dann als Wert 86400 Sekunden einzutragen. `
    Das hilft auch nicht, da die Zeit (86400 s) jedesmal neu startet, wenn ein Eintrag (Wertänderung) erfolgt. Wenn es immer um 23:59 Uhr sein soll, dann entweder einen extra Datenpunkt verwenden (was sich bei Verbrauchswerten anbietet) oder den Originaldatenpunkt zur Uhrzeit manipulieren.

    const idDp = '...';
    
    schedule('59 23 * * *', function() {
       var val = getState(idDp).val; 
       setState(idDp, val + 0.01, true);
       setState(idDp, val, true);
    });
    

    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
    • apollon77A Offline
      apollon77A Offline
      apollon77
      schrieb am zuletzt editiert von
      #7

      Korrekt.

      Wenn Du was anderes willst dann am besten per Javascript zu der Uhrzeit laufen lassen was den aktuellen Wert nimmt und in ein JavaScript-State schreibt. Den kannst Du wieder historisieren.

      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
      1 Antwort Letzte Antwort
      0
      • D Offline
        D Offline
        dtp
        schrieb am zuletzt editiert von
        #8

        Okay. Dann muss ich das wohl so realisieren. Hätte es halt praktisch gefunden, wenn man das durch einen einfachen Klick in der History-Konfiguration des Datenpunkts erledigen könnte.

        Auf jeden Fall vielen Dank an paul53 für das Skript. Verhindert das dann auch, dass der Datenpunkt trotz ertwaiger Änderung zu anderen Zeitpunkten geloggt wird? Mein Ziel ist es, nur ein einziges Mal am Tag - das aber ganz sicher - einen Datenpunkt zu loggen, egal, ob zwischendurch eine Werteänderung erfolgt ist, oder nicht.

        Gruß,

        Thorsten

        ioBroker im Docker-Container auf Synology DiskStation DS718+, HomeMatic IP über CCU3, IKEA Dirigera inkl. Matter, Apple Homekit, Amazon Alexa.

        1 Antwort Letzte Antwort
        0
        • paul53P Offline
          paul53P Offline
          paul53
          schrieb am zuletzt editiert von
          #9

          @dtp:

          Verhindert das dann auch, dass der Datenpunkt trotz ertwaiger Änderung zu anderen Zeitpunkten geloggt wird? `
          Nein, das Skript erzeugt zwei zusätzliche Einträge um 23:59 Uhr.
          @dtp:

          Mein Ziel ist es, nur ein einziges Mal am Tag - das aber ganz sicher - einen Datenpunkt zu loggen, egal, ob zwischendurch eine Werteänderung erfolgt ist, oder nicht. `
          Dann wird ein zusätzlicher Datenpunkt für History benötigt, der per Skript nur um 23:59 Uhr aktualisiert wird.

          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
          • D Offline
            D Offline
            dtp
            schrieb am zuletzt editiert von
            #10

            Danke. So hab ich es jetzt auch mal umgesetzt. Nicht ganz das, was ich ursprünglich wollte, aber immerhin ein funktionierender Workaround. ;)

            ioBroker im Docker-Container auf Synology DiskStation DS718+, HomeMatic IP über CCU3, IKEA Dirigera inkl. Matter, Apple Homekit, Amazon Alexa.

            1 Antwort Letzte Antwort
            0
            • B Offline
              B Offline
              backons
              schrieb am zuletzt editiert von
              #11

              Ich würde auch gerne um 23:59Uhr einen Wert speichern. Ich habe das Java-Script von paul53 genommen und in der ersten Zeile anstatt der "..." mein Objekt eingesetzt. Leider speichert es mir keinen Wert in eine neue Variable...
              Die Variable müsste ja dann unter den Objekten unter javascript.0 zu finden sein oder ?
              anbei mein Script:

              const idDp = 'smartmeter.0.1-0:1_8_0_255.value';
              
              schedule('59 23 * * *', function() {
                 var val = getState(idDp).val; 
                 setState(idDp, val + 0.01, true);
                 setState(idDp, val, true);
              });
              
              paul53P 1 Antwort Letzte Antwort
              0
              • B backons

                Ich würde auch gerne um 23:59Uhr einen Wert speichern. Ich habe das Java-Script von paul53 genommen und in der ersten Zeile anstatt der "..." mein Objekt eingesetzt. Leider speichert es mir keinen Wert in eine neue Variable...
                Die Variable müsste ja dann unter den Objekten unter javascript.0 zu finden sein oder ?
                anbei mein Script:

                const idDp = 'smartmeter.0.1-0:1_8_0_255.value';
                
                schedule('59 23 * * *', function() {
                   var val = getState(idDp).val; 
                   setState(idDp, val + 0.01, true);
                   setState(idDp, val, true);
                });
                
                paul53P Offline
                paul53P Offline
                paul53
                schrieb am zuletzt editiert von paul53
                #12

                @backons sagte:

                Die Variable müsste ja dann unter den Objekten unter javascript.0 zu finden sein oder ?

                Nein, im Datenpunkt "smartmeter.0.1-0:1_8_0_255.value" wird ein neuer Eintrag erzeugt.

                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

                B 1 Antwort Letzte Antwort
                0
                • paul53P paul53

                  @backons sagte:

                  Die Variable müsste ja dann unter den Objekten unter javascript.0 zu finden sein oder ?

                  Nein, im Datenpunkt "smartmeter.0.1-0:1_8_0_255.value" wird ein neuer Eintrag erzeugt.

                  B Offline
                  B Offline
                  backons
                  schrieb am zuletzt editiert von
                  #13

                  @paul53 jetzt hab ich s auch gesehen... Aber sehe ich es richtig das das Logging über history oder sql bei dem Datenpunkt aktiviert sein muss ?
                  Zumindest bei mir schreibt dein Script den Wert nur wenn es aktiviert ist und ansonsten leider nicht.
                  Ich hätte aber eigentlich gerne nur den einen Wert am Tag. Wenn ich das Logging aktiviere hab ich leider zahlreiche Werte und den einen um 23:59 was in einem Diagramm leider nicht gut aussieht...

                  paul53P 1 Antwort Letzte Antwort
                  0
                  • B backons

                    @paul53 jetzt hab ich s auch gesehen... Aber sehe ich es richtig das das Logging über history oder sql bei dem Datenpunkt aktiviert sein muss ?
                    Zumindest bei mir schreibt dein Script den Wert nur wenn es aktiviert ist und ansonsten leider nicht.
                    Ich hätte aber eigentlich gerne nur den einen Wert am Tag. Wenn ich das Logging aktiviere hab ich leider zahlreiche Werte und den einen um 23:59 was in einem Diagramm leider nicht gut aussieht...

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

                    @backons sagte:

                    Ich hätte aber eigentlich gerne nur den einen Wert am Tag.

                    Dann musst Du einen zusätzlichen Datenpunkt für die History erstellen, der nur einmal am Tag aktualisiert wird. Etwa so:

                    const idSrc = 'smartmeter.0.1-0:1_8_0_255.value';
                    const idHist = 'smartmeter.xyz'; // Anpassen !
                    
                    createState(idHist, 0, {
                       type: 'number', 
                       unit: 'W'} // Einheit anpassen !
                    ); 
                    
                    schedule('59 23 * * *', function() {
                       var val = getState(idSrc).val; 
                       setState(idHist, val, true);
                    });
                    

                    Der Datenpunkt befindet sich dann unter "javascript.0".

                    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
                    • T Offline
                      T Offline
                      thowas
                      schrieb am zuletzt editiert von
                      #15

                      Hallo,
                      ich benötige ebenfalls eine periodische Speicherung im SQL-/His- Adaper im Viertelstundenraster für unterschiedliche Messwerte.
                      In einem kostanten Raster lassen sich die Werte auch einfacher verrechnen oder vergleichen. In der allgemeinen Messtechnik ist es üblich Werte mit einer konstanten Periode zu speichern. Dabei wird der Wert am Ende der Periode gespeichert.
                      Verbreitete Perioden sind Minutenwerte, Viertelstundenwert, Stundenwerte und Tageswerte.
                      Diese erweiterte Funktionalität würde die Historiesierung für viele Messwerte erheblich vereinfachen und auch Speicherplatz sparen.

                      Gruß
                      Thomas

                      F 1 Antwort Letzte Antwort
                      0
                      • T thowas

                        Hallo,
                        ich benötige ebenfalls eine periodische Speicherung im SQL-/His- Adaper im Viertelstundenraster für unterschiedliche Messwerte.
                        In einem kostanten Raster lassen sich die Werte auch einfacher verrechnen oder vergleichen. In der allgemeinen Messtechnik ist es üblich Werte mit einer konstanten Periode zu speichern. Dabei wird der Wert am Ende der Periode gespeichert.
                        Verbreitete Perioden sind Minutenwerte, Viertelstundenwert, Stundenwerte und Tageswerte.
                        Diese erweiterte Funktionalität würde die Historiesierung für viele Messwerte erheblich vereinfachen und auch Speicherplatz sparen.

                        Gruß
                        Thomas

                        F Offline
                        F Offline
                        Fatmax
                        schrieb am zuletzt editiert von
                        #16

                        @thowas
                        Ich habe genau die selbe Thematik.
                        Eine Speicherung zu einer einstellbaren fixen Zeit sollte erfolgen. z.B.: Temperaturwerte immer zur vollen Stunde speichern.
                        Die Notlösung mit einem zusätzlichen Datenpunkt ist zwar machbar aber eigentlich bei vielen Datenpunkten umständlich.

                        Um mühsam durch die Entwickler bei jedem Datenpunkt in den SQL-Einstellungen einen Cron einzubauen und dies dann durch die User einzeln einzustellen wäre die Überlegung ob es denkbar wäre automatisch ein Triggerobjekt pro überwachten Datenpunkt durch den Adapter zu erzeugen?
                        Das Triggerobjekt könnte man dann beliebig per Javascript auf "True" setzen und die Speicherung von dem zugehörigen Datenpunkt würde dann manuell ausgelöst werden.

                        @apollon77 soll ich dazu ein Issue auf Git anlegen?
                        Ich denke eine Anforderung ist vorhanden ☺

                        Liebe Grüße,
                        Fatmax

                        T 1 Antwort Letzte Antwort
                        0
                        • F Fatmax

                          @thowas
                          Ich habe genau die selbe Thematik.
                          Eine Speicherung zu einer einstellbaren fixen Zeit sollte erfolgen. z.B.: Temperaturwerte immer zur vollen Stunde speichern.
                          Die Notlösung mit einem zusätzlichen Datenpunkt ist zwar machbar aber eigentlich bei vielen Datenpunkten umständlich.

                          Um mühsam durch die Entwickler bei jedem Datenpunkt in den SQL-Einstellungen einen Cron einzubauen und dies dann durch die User einzeln einzustellen wäre die Überlegung ob es denkbar wäre automatisch ein Triggerobjekt pro überwachten Datenpunkt durch den Adapter zu erzeugen?
                          Das Triggerobjekt könnte man dann beliebig per Javascript auf "True" setzen und die Speicherung von dem zugehörigen Datenpunkt würde dann manuell ausgelöst werden.

                          @apollon77 soll ich dazu ein Issue auf Git anlegen?
                          Ich denke eine Anforderung ist vorhanden ☺

                          T Offline
                          T Offline
                          thowas
                          schrieb am zuletzt editiert von
                          #17

                          @Fatmax
                          Die Anforderung wird immer noch benötigt - bitte ein Issue auf Git anlegen.
                          Vielen Dank

                          1 Antwort Letzte Antwort
                          0

                          Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

                          Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

                          Mit deinem Input könnte dieser Beitrag noch besser werden 💗

                          Registrieren Anmelden
                          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

                          497

                          Online

                          32.8k

                          Benutzer

                          82.9k

                          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