如何将带有"$"字段的JSON对象插入流星集合?



我正在从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。

最新更新