首页 > 解决方案 > 节点红色多个值到 influxDB

问题描述

我尝试使用 Node Red 构建一个查询,使用以下代码将多个值从循环发送到 influxDB:

var inputArray = msg.payload;
var lenInputArray =inputArray.length;
var modbusStartRegister = 14000;

var sendString = "";

var msg93 ={};


for (i = 0; i < lenInputArray; i++) {
    var actRegister = modbusStartRegister +i;
    var actValue = inputArray[i];
    if ( i >=1){
        sendString =  sendString + " ,"
    }
    sendString = sendString +"{register: " + actRegister +"," +"value: " + actValue +"}";
    if ( i ==(lenInputArray-1)){
        sendString =  sendString + "]"
    }
}

msg93.payload = sendString;

    
return msg93

但是 influxDB 中的插入是一行,它将它们视为一个完整的字符串。如何构建或转换数据库接受它们作为单独条目的字符串?谢谢您的帮助

标签: javascriptinfluxdbnode-red

解决方案


这是因为您正在构建一个字符串,节点是一个对象。

您可以像这样动态构建数组对象:

var inputArray = msg.payload;
var lenInputArray =inputArray.length;
var modbusStartRegister = 14000;

var payload = [];

var msg93 ={};


for (i = 0; i < lenInputArray; i++) {
    var temp = {};
    temp.register = modbusStartRegister +i;
    temp.value = inputArray[i];
    payload.push(temp);

}

msg93.payload = payload;


return msg93

推荐阅读