zoukankan      html  css  js  c++  java
  • MongoDB插入数据的3种方法

     

    insert()方法:

    下面是在inventory集合中插入一个三个字段的文档:

    db.inventory.insert( { _id: 10, type: "misc", item: "card", qty: 15 } )
    

    在示例中,文档有一个用户指定的值为10的_id字段,这个值必须在inventory集合中唯一。

    update()方法:

    调用update()方法使用upsert标志创建一个新文档当没有匹配查询条件的文档时。下面的例子当inventory集合中没有包含{type:"books",item:"journal"}的文档时创建一个新文档:

    db.inventory.update(
                             { type: "book", item : "journal" },
                             { $set :     { qty: 10 } },
                             { upsert :true     }
                    )
    

    MongoDB添加_id字段和分配一个唯一的ObjectId作为它的值。新文档包含来自查询条件的item和type字段,和来自更新参数的qty字段:

    { "_id" : ObjectId("51e8636953dbe31d5f34a38a"), "item" : "journal", "qty" : 10, "type" : "book" }
    

    save()方法:

    使用save()方法插入一个文档,通过该方法保存一个不包含_id字段的文档或者包含_id字段但该字段值不存在集合中的文档。下面的示例创建一个新的文档在inventory集合:

    db.inventory.save( { type: "book", item: "notebook", qty: 40 } )
    

    MongoDB添加_id字段和分配一个唯一的ObjectId作为它的值。

    { "_id" : ObjectId("51e866e48737f72b32ae4fbc"), "type" : "book", "item" : "notebook", "qty" : 40 }
    

    当在使用save方法时,插入不指定_id时,会自动生成一个。
    Insert和Save的区别是:如果插入的集合的“_id”值,在集合中已经存在,用Insert执行插入操作会报异常,已经存在"_id"的键。用Save如果系统中没有相同的"_id"就执行插入操作,有的话就执行覆盖掉原来的值。相当于修改操作。

  • 相关阅读:
    Mysql技术内幕——InnoDB存储引擎
    Nginx 0.7.x + PHP 5.2.6(FastCGI)+ MySQL 5.1 在128M小内存VPS服务器上的配置优化
    Mysql5.5 InnoDB存储引擎配置和优化
    MySQL存储引擎总结
    MySQL存储引擎--MyISAM与InnoDB区别
    MySQL存储引擎
    Mysql的建表规范与注意事项
    安装好oracle11gR2之后在相应路径下却没有生成tnsnames.ora和listener.ora
    split切割.号的字符串
    配置文件c3p0-config.xml
  • 原文地址:https://www.cnblogs.com/xiaoyuxixi/p/13803087.html
Copyright © 2011-2022 走看看