MongoDB在数组中添加和删除字段

时间:2016-09-29 14:12:24

标签: javascript mongodb mongodb-query

我正在开发一个使用MongoDB的项目,但我从未使用它。 我明白通过使用javascript,你可以操纵数据库。我制作了一个删除一些字段并添加其他字段的脚本,但它没有正常工作:

1001

调用db.floor.find({_id:"003"}).forEach( function(doc) { // Find floor with id = 003. var tiles = doc.tiles; // Get tiles from floor. for(var i = 0; i < tiles.length; i++){ // Loop through tiles. var tile = tiles[i]; // Get tile at index i. if (tile.nodeType){ // If tile has a field "nodeType", tile.tileType = tile.nodeType; // add a field "tileType" delete tile.nodeType; // and delete the "nodeType" field. } // THIS CODE BELOW IS NOT WORKING var sensors = tile.sensors; // Get sensors of tile. for(var j = 0; j < sensors.length; j++){ // Loop through sensors. var sensor = sensors[j]; // Get sensor at index j. if (sensor.state){ // If sensor has a field "state", sensor.activated = sensor.state; // add a field "activated" delete sensor.state; // and delete the "state" field. } } } db.floor.save(doc); }); 时,我的楼层已保存。现在,所有图块都有一个名为db.floor.save(doc)的字段,但没有传感器有一个名为tileType的字段!所有传感器仍然有activated。我不知道什么不起作用,我对瓷砖和传感器使用相同的代码。请帮忙。

<小时/> 这是场内的结构:

state

}

1 个答案:

答案 0 :(得分:7)

@sumitchoudhary的评论:

使用if(sensor.state)核对时,会检查sensor.state的值是否真实。我所有的传感器状态都是假的。所以我从来没有进入if语句......对于if(tile.nodeType)来说它是不同的,因为它有一个字符串,并且总是真实的(对于我的值)。

<小时/> 正确的检查需要:

if ("state" in sensor)
{ 
    // If sensor has a field "state", 
    sensor.activated = sensor.state; // add a field "activated"
    delete sensor.state; // and delete the "state" field.
}