插入文档
db.collection.insertOne() 用于向集合插入一个新文档,如下:
db.movies.insertOne({"title" : "Stand by Me"})
db.collection.insertMany() 用于向集合插入一个多个文档,如下:
db.movies.insertMany( [ {"_id": 3, "title": "Sixteen Candles"}, {"_id": 4, "title": "The Terminator"} ], {"ordered": false})
ordered:指定是否按顺序写入,默认 true,按顺序写入。
虽然 insert 等方法仍然支持向后兼容,但今后不应该在应用程序中继续使用。应该使用 insertOne 和insertMany 来创建文档。
更新文档
updateOne、updateMany 和 replaceOne。
updateOne 和 updateMany都将筛选文档作为第一个参数,将变更文档作为第二个参数,后者对要进行的更改进行描述。
replaceOne 同样将筛选文档作为第一个参数,但第二个参数是一个用来替换所匹配的筛选文档的新文档。
更新文档是原子操作:如果两个更新同时发生,那么首先到达服务器的更新会先被执行,然后再执行下一个更新。
db.movies.replaceOne( {"_id": 1} , {"_id": 1, "title": "mongo111"} );
更新运算符
"$set" 用来设置一个字段的值。如果这个字段不存在,则创建该字段。
db.movies.updateOne({"_id": 1}, {"$set": {"a1.a11": "a11"}})
可以用 "$unset" 将这个键完全删除
db.movies.updateOne({"_id": 1}, {"$unset": {"a1": ""}})