我正在使用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' ] }
我可能错过了一些东西,但我不知道是什么。 如果我将路径存储在字符串而不是数组中,它可以很好地工作,但我发现它不那么优雅和方便。
答案 0 :(得分:3)
我不确定所有的Sails / Waterline部件,因为我从来没有玩过它。但是由于错误,问题是您的数组字段上有唯一索引。
当您插入第二个文档时,您已在另一个文档的路径字段中拥有其中一个值(父级)。唯一约束不允许这样做。对于你正在建模的东西,你肯定不需要这个,索引不能是唯一的。
我希望你自己设置它,假设它在文档中包含的数组中是唯一的。如果你这样做,那么你知道在哪里看,现在要改变什么。如果以某种方式自动部署,那么我就不是那个需要帮助的人。
将索引更改为不唯一。你可以通过mongo shell确认这个:
use cms-project
db.item.getIndices()
祝你好运