如何从文档中删除字段

时间:2013-08-29 08:22:02

标签: mongodb meteor

数据库架构:

{
    _id: "kun2",
    result150160: [10,20,30];
    moon: 4
}

我想通过变量:

删除客户端的整个字段result150160
var deleteresult = "result150160"
Box.update( {_id: this._id} , {$unset: { deleteresult } } );

3 个答案:

答案 0 :(得分:13)

正确的语法是:

Box.update( {_id: this._id} , {$unset: { deleteresult : "" } } );

您必须为$unset操作指定一个值:{ deleteresult : "" }。即使它是空的。

结帐relevant docs

  

<强> 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);