我是MongoDB的新手。我已经以下面的格式将数据存储在mongoDB中
"_id" : ObjectId("51d5725c7be2c20819ac8a22"),
"chrom" : "chr22",
"pos" : 17060409,
"information" : [
{
"name" : "Category",
"value" : "3"
},
{
"name" : "INDEL",
"value" : "INDEL"
},
{
"name" : "DP",
"value" : "31"
},
{
"name" : "FORMAT",
"value" : "GT:PL:GQ"
},
{
"name" : "PV4",
"value" : "1,0.21,0.00096,1"
}
],
"sampleID" : "Job1373964150558382243283"
我想将值更新为11,其名称为Category
。
我试过下面的查询:
db.VariantEntries.update({$and:[ { "pos" : 117199533} , { "sampleID" : "Job1373964150558382243283"},{"information.name":"Category"}]},{$set:{'information.value':'11'}})
但是Mongo回复
can't append to array using string field name [value]
如何形成一个更新特定值的查询?
答案 0 :(得分:3)
您可以使用$
位置运算符来标识第一个数组元素以匹配更新中的查询,如下所示:
db.VariantEntries.update({
"pos": 17060409,
"sampleID": "Job1373964150558382243283",
"information.name":"Category"
},{
$set:{'information.$.value':'11'}
})
答案 1 :(得分:0)
在MongoDB中,您不能以这种方式处理数组值。因此,您应该将架构设计更改为:
"information" : {
'category' : 3,
'INDEL' : INDEL
...
}
然后,您可以解决查询中的单个字段:
db.VariantEntries.update(
{
{"pos" : 117199533} ,
{"sampleID" : "Job1373964150558382243283"},
{"information.category":3}
},
{
$set:{'information.category':'11'}
}
)