NEWS
Ausgabe Node-Red an Datenpunkt
-
Hallo,
über Node-Red frage ich eine MySql Datenbank ab.
Das Ergebnis ist im Beispiel der Wert "1878".
Auf dem Datenpunkt im ioBroker kommt jedoch der gesamte Text mit an also "Sum(ack): 1878"Wie kann ich den Text entfernen so dass nu noch der Nummerische Wert übergeben wird?
-
@toby-2 Indem Du aus dem Array von Objekten den Wert extrahierst. Am Besten ist immer Du gehst mit der Maus neben den Wert und kopierst den Pfad raus.
Ich zeige es Dir an Deinem Beispiel. In Deinem Fall ist es ein klein wenig komplizierter, weil der Pfad in JS notation kommt, deswegen den Pfad wie folgt modifizieren.
Hier die Change-Node um den Wert zu extrahieren als Import:
Wie gesagt in Deinem Fall muss man leider an den Pfad Hand anlegen.
Aus dem kopierten Pfad:
payload[0]["Sum (ack)"]
musst Du erst die Punkt-Notation nutzen.
payload.0["Sum (ack)"]
-
@toby-2 Alternativ empfehle ich Dir aber in diesem Fall ein Array - also wenn ein Schwung von Werten kommt die erst in einzelne Nachrichten aufzudröseln.
Die spit Node macht also zum Beispiel aus dem Array einzelne Nachrichten wenn Du nun den Pfad kopierst dann kannst Du ihn direkt verwenden.
payload["Sum (ack)"]
Später kannst Du Dich auch mit JSONATA beschäftigen - eine sehr mächtige Bibliothek, die in NodeRed eingebaut ist und die Dir im ersten Schritt auch ein Array mit den extrahierten Werten aus dem Objekt liefert.
-
@mickym
Super mickym, Vielen Dank!
Das funktioniert klasse mit deinem ersten Vorschlag. Ich taste mich da mal weiter voran -
Wenn Du über die SQL-Abfrage nur 1 Feld abfragst, dann ist der Feldname eigentlich unwichtig und Deine Objekte bestehen nur aus einer Eigenschaft - dann ist der Name dieser Eigenschaft auch egal. Dann kannst Du auch direkt JSONATA verwenden. Diese Form ist also universell einsetzbar - solange Du nur 1 Feld abfragst!
Du siehst auch das funktioniert.
-
-
@mickym Und noch ein TIPP - vermeide function Nodes so gut es geht - auch wenn Du da oft Beispiele setzt.
In Deiner function Node wird nur so was drinstehen:
msg.topic = "SELECT ...."
setzte das topic einfach über eine Change Node:
gewöhne Dir den anderen Mist gar nicht an.
Auch wenn Du selbst mit einer Inject Node triggern willst. Auch dort kannst Du direkt Deine select Abfrage ins topic schreiben:
Du siehst eine SQL Abfrage einfach in das topic der Nachrichteigenschaft rein schreiben, das geht auch mit einer Inject Node.
Später wirst Du Dir für komplexere Abfragen aus verschiedenen Nachrichteneigenschaften Deine SQL Abfrage ggf. basteln:
in diese Template Node (SQL get events) kannst Du dann Deine SQL Abfrage formulieren und variabel mit Deinen Nachrichteneigenschaften verändern.
-