我正在从Amazon API检索有关书籍的数据并将其存储为JSON对象。然后,我想将此数据插入到 Meteor 集合中。但是,JSON 数据中的某些字段以"$"字符开头,这会导致此错误:
MongoError: 'result.results.0.ItemAttributes.0.ManufacturerMaximumAge.0.$' 中的美元 ($( 前缀字段"$"对于存储无效。
鉴于数据包含"$"符号,我希望帮助将数据插入集合中。如果这是不可能的,有没有办法删除 JSON 数据中所有出现的"$",然后将其存储到 Meteor 集合中?以下是我的代码,给定书名和作者,用于搜索 Amazon API 并返回有关前 10 个结果的信息:(搜索结果是对集合的引用(
Meteor.methods({
itemSearch(appUUID,title, author) {
var result = {};
result.search = {
appUUID: appUUID,
title: title,
author: author
}
client.itemSearch({
title: title,
author: author,
searchIndex: 'Books',
responseGroup: 'ItemAttributes, Images'
}).then(function(results){
result.results = results;
var upsertResult = SearchResult.upsert( {
appUUID: appUUID,
title: title,
author: author,
},
{
$set: {result: result}
}
);
}).catch(function(err){
SearchResult.upsert({
appUUID: appUUID,
title: title,
author: author,
},
{
$set: {result: result }
}
);
});
}
});
这是 JSON 数据,"单位"之前的美元符号是导致问题的原因。
"Width": [
{
"_": "810",
"$": {
"Units": "hundredths-inches"
}
}
]
简单的答案是,不,您不能在MongoDB的字段中使用该$
(来自文档(:
有许多字段名称不能以美元符号 ($( 字符开头。
可能的解决方案可以将您的数据更改为MongoDB可以接受的格式,但是为了给您我能想到的最简单的解决方案,您可以只映射对象的键。例如,使用 lodash 的 mapKeys
函数:
data = _.mapKeys(data, (value, key) => {
if(key === '$') {
return 'some_custom_key'
} else {
return key
}
})
这会将您的所有$
更改为some_custom_key
。只要你有钩子(例如 Mongoose 的 pre save
中间件和 post read
中间件、文档(可以在后台为您转换它,它应该是一个可行的解决方案。
我不知道这是否可能,但更好的解决方案是让 Amazon API 在没有$
的情况下为您提供数据,但我无法推测,因为我不熟悉该 API。