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

问题描述

我正在从结构数组转换为查询效果很好,但是在我拥有数组和嵌套结构的情况下,我有点迷失了我应该在函数修改内容,以获取具有更改后的数据的查询

我有以下代码

<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 stackoverflow(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>