ネストした配列に新しいデータを追加したい
私の文書は:
{
"username": "erkin",
"email": "[email protected]",
"password": "b",
"playlists": [
{
"_id": 58,
"name": "asdsa",
"date": "09-01-15",
"musics": [
{
"name": "INNA - Cola Song (feat. J Balvin)",
"duration": "3.00"
},
{
"name": "blabla",
"duration": "3.00"
}
]
}
]
}
このプレイリストセクションに音楽を追加します。
{
"username": "erkin",
"email": "[email protected]",
"password": "b",
"playlists": [
{
"_id": 58,
"name": "asdsa",
"date": "09-01-15",
"musics": [
{
"name": "INNA - Cola Song (feat. J Balvin)",
"duration": "3.00"
},
{
"name": "blabla",
"duration": "3.00"
},
{
"name": "new",
"duration": "3.00"
}
]
}
]
}
ここに私が試したものがあります:
$users->update(
array(
'_id' => new MongoId (Session::get('id')),
'playlists._id' => $playlistId
),
array(
'$Push' => array('playlists.musics' => array(
'name' => 'newrecord',
'duration' => '3.00'
))
)
);
おそらく、IDがObjectIdであるようなものです。最初の{}は、ドキュメントを識別するために必要です。コレクションに別の一意の識別子がある限り、ObjectIdを使用する必要はありません。
db.collection.update(
{ "_id": ID, "playlists._id": "58"},
{ "$Push":
{"playlists.$.musics":
{
"name": "test name",
"duration": "4.00"
}
}
}
)
このようにそれは私のために働いた!
"playlists。$ []。musics":
db.collection.update(
{ "_id": ID, "playlists._id": "58"},
{ "$Push":
{"playlists.$[].musics":
{
"name": "test name",
"duration": "4.00"
}
}
}
)