Sails.js& MongoDB:重复键错误索引

时间:2014-02-10 04:57:42

标签: node.js mongodb sails.js waterline

我正在使用Sails.js(0.9.8)和MongoDB(通过sails-mongo适配器)来创建可以在树视图中定位的页面集合。我想将页面的路径存储在UUID数组

我的模特:

module.exports = {    
    schema: true,
    attributes: {
        uuid: {
            type: 'string',
            unique: true,
            required: true,
            uuidv4: true
        },
        name: {
            type: 'string',
            required: true,
            empty: false
        },
        path: {
            type: 'array',
            required: true,
            array: true
        }
    }
}

当我保存“根”页面时效果很好('path'属性只有一个项目,因为它是一个根页面。这是它在MongoDB中保存的内容:

{
    _id: ObjectId("52f853e9609fb6c0341bdfcc"),
    createdAt: ISODate("2014-02-10T04:22:01.828Z"),
    name: "Home Page",
    path: [
        "a2b23e1f-954b-49a3-91f1-4d62d209a093"
    ],
    updatedAt: ISODate("2014-02-10T04:22:01.833Z"),
    uuid: "a2b23e1f-954b-49a3-91f1-4d62d209a093"
}

但是当我想在我之前创建的页面(主页/产品)下创建一个“子页面”时,我收到此错误:

  

MongoError:E11000重复键错误索引:cms-project.item。$ path_1   dup key:{:“a2b23e1f-954b-49a3-91f1-4d62d209a093”}

以下是我发送的数据:

{ name: 'Products',
  uuid: 'a004ee54-7e42-49bf-976c-9bb93c118038',
  path: 
   [ 'a2b23e1f-954b-49a3-91f1-4d62d209a093',
     'a004ee54-7e42-49bf-976c-9bb93c118038' ] }

我可能错过了一些东西,但我不知道是什么。 如果我将路径存储在字符串而不是数组中,它可以很好地工作,但我发现它不那么优雅和方便。

1 个答案:

答案 0 :(得分:3)

我不确定所有的Sails / Waterline部件,因为我从来没有玩过它。但是由于错误,问题是您的数组字段上有唯一索引。

当您插入第二个文档时,您已在另一个文档的路径字段中拥有其中一个值(父级)。唯一约束不允许这样做。对于你正在建模的东西,你肯定不需要这个,索引不能是唯一的。

我希望你自己设置它,假设它在文档中包含的数组中是唯一的。如果你这样做,那么你知道在哪里看,现在要改变什么。如果以某种方式自动部署,那么我就不是那个需要帮助的人。

将索引更改为不唯一。你可以通过mongo shell确认这个:

use cms-project
db.item.getIndices()
祝你好运