微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决将嵌套结构的数组转换为查询

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

我有以下代码

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。