gpt4 book ai didi

javascript - 将 JavaScript 对象转换为数组以插入关系数据库

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:41:05 25 4
gpt4 key购买 nike

我正在使用 Nodejs。我需要在关系数据库中存储一个 JavaScript 对象。 JavaScript 对象中的每个键代表数据库中的列名。我有以下内容:

var data = {
"aa": "99",
"bb": ["11","22"],
"cc": ["44","55","66"]
}

我想将这个对象转换成一个数组,如下所示:

  data =  [
{
"aa": "99",
"bb": "11",
"cc": "44"
},
{
"aa": "99",
"bb": "11",
"cc": "55"
},
{
"aa": "99",
"bb": "11",
"cc": "66"
},
{
"aa": "99",
"bb": "22",
"cc": "44"
},
{
"aa": "99",
"bb": "22",
"cc": "55"
},
{
"aa": "99",
"bb": "22",
"cc": "66"
}
]

有什么办法吗?我想使用递归我们可以做到。但无法在 Google 中找到任何引用。

最佳答案

您可以将迭代和递归方法与组合算法结合使用。

这个解决方案基本上是遍历给定的数据(一个数组由对象组成)并在数组内部遍历项目。在这种情况下,您有一个包含三个数组的数组。

[
["99"],
["11","22"],
["44","55","66"]
]

它从第一个数组开始并迭代。这里只有一个项目,迭代的回调检查部分长度,如果它等于给定的数组长度,则准确地找到所有项目。这是退出迭代并将收集的部分推送到结果数组的条件。 (项目在 reduce 回调中转换为对象。)

如果部分数组没有所需的长度,则继续处理外部数组的下一项。

基本上迭代和回归的工作方式如下

part       0      1      2   action
------ ----- ----- ---------------
99 go to next level
99 11 go to next level
99 11 44 push to result, end level 2
99 11 55 push to result, end level 2
99 11 66 push to result, end level 2
99 11 end level 1
99 22 go to next level
99 22 44 push to result, end level 2
99 22 55 push to result, end level 2
99 22 66 push to result, end level 2
99 22 end level 1
99 end level 0

function combine(object) {
function c(part) {
array[part.length].forEach(function (a) {
var p = part.concat(a);
if (p.length === array.length) {
result.push(p.reduce(function (r, b, i) {
r[keys[i]] = b;
return r;
}, {}));
return;
}
c(p);
});
}

var keys = Object.keys(object),
array = keys.map(function (k) { return Array.isArray(object[k]) ? object[k] : [object[k]]; }),
result = [];

c([]);
return result;
}

var data = { aa: "99", bb: ["11", "22"], cc: ["44", "55", "66"] },
result = combine(data);

console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }

关于javascript - 将 JavaScript 对象转换为数组以插入关系数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40867610/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com