将嵌套结构数组转换为查询

converting array of nested structure to query

我正在从结构数组转换为查询,工作正常,但在我有数组和嵌套结构的情况下,我有点迷失了我应该在函数中修改什么以获取包含已更改数据的查询。

我有以下代码

<cfscript>
data = [
    {"1" :
        { i: 1, label: "One" }
    },
    {"2" :{ i: 2, label: "Two", foo: "Foo" }},
    {"3" :{ i: 3, label: "Three", bar: "Bar" }},
    {"4" :{ i: 4, label: "Four", foo: "Foo", bar: "Bar" }}
];
  
function Whosebug(data) {
    return data.reduce(function(accumulator, element) {
        element.each(function(key) {
            if (!accumulator.keyExists(key)) {
            accumulator.addColumn(key, []);
            }
        });
        accumulator.addRow(element);
        return accumulator;
    }, QueryNew(""));
}

writeDump(data); abort;
writeDump(arrayToQuery(data));
</cfscript>

上面的工作正常,如果它是一个简单的 ArrayofStructs 但只要我添加一个结构级别它就会停止工作

为什么不先将嵌套数组格式化为更简单的数组格式,然后像这样进行归约。总有更好的解决方案,但这一切都取决于您应用中的业务逻辑。

<cfscript>
  data = [
      {"1" :{ i: 1, label: "One" }},
      {"2" :{ i: 2, label: "Two", foo: "Foo" }},
      {"3" :{ i: 3, label: "Three", bar: "Bar" }},
      {"4" :{ i: 4, label: "Four", foo: "Foo", bar: "Bar" }}
  ];
  function arrayToQuery(data) {
    return data.map(function(datum, index){
        return datum[index];
      }).reduce(
        function(accumulator, element) {
          element.each(function(key) {
            if (!accumulator.keyExists(key)) {
              accumulator.addColumn(key, []);
            }
          });
          accumulator.addRow(element);
          return accumulator;
        },
        QueryNew("")
      );
  }

  writeDump(data); 
  writeDump(arrayToQuery(data));
</cfscript>