26

mongodb コレクションにオブジェクトがあります。そのスキーマは次のとおりです。

{
    "instruments": ["A", "B", "C"],
    "_id": {
        "$oid": "508510cd6461cc5f61000001"
    }
}

私のコレクションにはそのようなオブジェクトがあるかもしれませんが、ないかもしれません。キー「instruments」を持つオブジェクトが存在するかどうかを確認する必要があります (この時点で「instrument」の値がわからないことに注意してください。任意の値または配列が含まれている可能性があります)。存在する場合は更新を実行し、そうでない場合は更新を実行します。 – 新しい値を挿入します。これどうやってするの?

collection.find( {  "instruments" : { $exists : true } }, function(err, object){
    if (object) {
        //update
    } else {
        //insert
    }
});

動作しません ((

4

1 に答える 1

24

ドキュメントが見つからない場合に 1 つのドキュメントを挿入する場合は、メソッドでupsertオプションを使用できます。update()

collection.update(_query_, _update_, { upsert: true });

アップサートの動作については、ドキュメントを参照してください。

$existsオペレーターの例。

コレクションに 6 つのドキュメントがあるとします。

> db.test.find()
{ "_id": ObjectId("5495aebff83774152e9ea6b2"), "a": 1 }
{ "_id": ObjectId("5495aec2f83774152e9ea6b3"), "a": [ ] }
{ "_id": ObjectId("5495aec7f83774152e9ea6b4"), "a": [ "b" ] }
{ "_id": ObjectId("5495aecdf83774152e9ea6b5"), "a": [ null ] }
{ "_id": ObjectId("5495aed5f83774152e9ea6b7"), "a": [ 0 ] }
{ "_id": ObjectId("5495af60f83774152e9ea6b9"), "b": 2 }

特定のフィールドを持つドキュメントを検索したい場合)、 $exists演算子 (ノード docs )でメソッドを"a"使用できます。注: これは、フィールドが空の配列であるドキュメントも返します。find()

> db.test.find( { a: { $exists: true } } )
{ "_id": ObjectId("5495aebff83774152e9ea6b2"), "a": 1 }
{ "_id": ObjectId("5495aec2f83774152e9ea6b3"), "a": [ ] }
{ "_id": ObjectId("5495aec7f83774152e9ea6b4"), "a": [ "b" ] }
{ "_id": ObjectId("5495aecdf83774152e9ea6b5"), "a": [ null ] }
{ "_id": ObjectId("5495aed5f83774152e9ea6b7"), "a": [ 0 ] }
于 2012-10-22T12:22:46.717 に答える