NEWS
History-Adapter (insb. SQL) mit periodischer Datenspeicherung
-
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
-
@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. -
Danke. So hab ich es jetzt auch mal umgesetzt. Nicht ganz das, was ich ursprünglich wollte, aber immerhin ein funktionierender Workaround.
-
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); });
-
@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.
-
@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... -
@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".
-
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 -
@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 -
@Fatmax
Die Anforderung wird immer noch benötigt - bitte ein Issue auf Git anlegen.
Vielen Dank