数据库架构:
{
_id: "kun2",
result150160: [10,20,30];
moon: 4
}
我想通过变量:
删除客户端的整个字段result150160var deleteresult = "result150160"
Box.update( {_id: this._id} , {$unset: { deleteresult } } );
答案 0 :(得分:13)
正确的语法是:
Box.update( {_id: this._id} , {$unset: { deleteresult : "" } } );
您必须为$unset
操作指定一个值:{ deleteresult : "" }
。即使它是空的。
<强>
db.collection.update( { field: value1 }, { $unset: { field1: "" } } );
强>
上面的示例从字段值为value1的文档中删除集合中的field1。 $ unset语句中字段的值(即上面的“”)不会影响操作。
答案 1 :(得分:1)
你可以这样做:
var deleteresult = {};
deleteresult["result150160"] = true
Box.update( {_id: this._id} , {$unset: deleteresult } );
基本上你必须使用一个键值对,只要在那里使用true
并不重要。
答案 2 :(得分:1)
试试这个它应该适合你:
var deleteresult = "result150160";
var updateQuery={$unset:{}};
updateQuery.$unset[deleteresult]=1;
Box.update( {_id: this._id} ,updateQuery,false,true);