iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MongoDB修改数据update和save方法
  • 211
分享到

MongoDB修改数据update和save方法

2024-04-02 19:04:59 211人浏览 独家记忆
摘要

    前面我简单介绍了下mongoDB怎样插入数据.那么数据插入到数据库中,就可能会修改数据.在MonGoDB中,它提供了修改数据的方法:update.下面,我来简单说下up

    前面我简单介绍了下mongoDB怎样插入数据.那么数据插入到数据库中,就可能会修改数据.在MonGoDB中,它提供了修改数据的方法:update.下面,我来简单说下update的使用方法.
首先,我们操作的数据都存放在test数据库中的name集合,集合中有4条记录如下:
> db
test
> show collections
name
system.indexes
> db.name.find()
{ "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "xiaoqiang", "lname" : "he" }
{ "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "dengdeng", "lname" : "pan" }
{ "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
下面我们来试着修改一下这些数据.在前面的插入中,我说过,插入时可以以文档的的方式插入,也可以先把文档赋值给变量,再以变量的方式插入.update方法也可以用这两种方式.我先用文档的方式来修改集合中的第二条记录,命令如下:
> db.name.update({"_id" : ObjectId("5059223a955cfb1fd75066cc")},{"fname" : "qiang", "lname" : "he"})
> db.name.find()    #检查发现,数据修改过来了,和预期的结果一样
{ "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
{ "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "dengdeng", "lname" : "pan" }
{ "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
我们再用变量的方式来修改该集合中的第三条记录.首先将它找出来赋值给变量someone:
> someone=db.name.findOne({"_id" : ObjectId("50592245955cfb1fd75066cd")})
{
    "_id" : ObjectId("50592245955cfb1fd75066cd"),
    "fname" : "dengdeng",
    "lname" : "pan"
}
重新赋值你要修改的内容来修改变量someone的值:
> someone.fname="deng"
deng
用修改过的变量替换之前文档的位置来达到修改数据的目的:
> db.name.update({"_id" : ObjectId("50592245955cfb1fd75066cd")},someone)
> db.name.find()    #检查发现,数据修改过来了,和预期的结果一样
{ "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
{ "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
{ "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
之前我说过,save函数实际就是根据参数条件,调用了insert或update函数.那么save方法是否也能实现数据的修改操作呢?下面我们来实验一下.首先还是以文档的方式来进行修改操作:
> db.name.save({"_id" : ObjectId("50592253955cfb1fd75066ce")}, {"fname" : "dongren", "lname" : "zeng"})
> db.name.find()    #检查发现,数据修改过来了,但和预期的结果不一样,跟之前插入数据一样,save方法也同样将第二个参数"忽略"了.
{ "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
{ "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
{ "_id" : ObjectId("50592253955cfb1fd75066ce") }
正确的操作方式如下:
> db.name.save({"_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "dongren", "lname" : "zeng"})
> db.name.find()    #检查发现,数据修改过来了,和预期的结果一样
{ "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
{ "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
{ "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "dongren", "lname" : "zeng" }
下面使用变量的方式来修改:
> someone=db.name.findOne({"_id" : ObjectId("50592253955cfb1fd75066ce")})
{
    "_id" : ObjectId("50592253955cfb1fd75066ce"),
    "fname" : "dongren",
    "lname" : "zeng"
}
> someone.fname="guage"
guage
> db.name.save(someone)
> db.name.find()    #检查发现,数据修改过来了,和预期的结果一样
{ "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
{ "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
{ "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
下面,我们也同样来看看save和update这两方法的具体实现.首先是save方法:
> db.name.save
function (obj) {
    if (obj == null || typeof obj == "undefined") {
        throw "can't save a null";
    }
    if (typeof obj == "number" || typeof obj == "string") {
        throw "can't save a number or string";
    }
    if (typeof obj._id == "undefined") {
        obj._id = new ObjectId;
        return this.insert(obj);
    } else {
        return this.update({_id:obj._id}, obj, true);
    }
}
参数说明:
    obj:要更新的记录,只能是单条记录,如果collection没有存在与obj一样的id,则添加一条记录,否则更新.
再来看看update方法:
> db.name.update
function (query, obj, upsert, multi) {
    assert(query, "need a query");
    assert(obj, "need an object");
    var firsTKEy = null;
    for (var k in obj) {
        firstKey = k;
        break;
    }
    if (firstKey != null && firstKey[0] == "$") {
        this._validateObject(obj);
    } else {
        this._validateForStorage(obj);
    }
    if (typeof upsert === "object") {
        assert(multi === undefined, "Fourth argument must be empty when specifying upsert and multi with an object.");
        opts = upsert;
        multi = opts.multi;
        upsert = opts.upsert;
    }
    this._db._initExtrainfo();
    this._mongo.update(this._fullName, query, obj, upsert ? true : false, multi ? true : false);
    this._db._getExtraInfo("Updated");
}
参数说明:
        1)query:查询条件,类似于update语句内where后面的内容
        2)obj:update的对象和一些更新的操作符(如$、$inc等),也可以理解为关系型数据库update语句内set后面的内容
        3)upsert:如果不存在update的纪录,是否插入obj这个新的document。true为插入,默认是false,不插入
        4)multi:默认是false,只更新找到的第一条纪录,如果为true,按条件查出来的多条纪录全部更新。

   update方法至少得接收两个参数:要修改的对象(query)和修改后的对象(obj),而后两个参数它的默认值均为false.下面我再来简单实验下,后两个参数的基本用法.
   首先说说第四个参数multi的作用:默认是false,只更新找到的第一条纪录,如果为true,按条件查出来的多条纪录全部更新.
> db.name.update({fname:"jeff"},{$set:{lname:"li"}},false,false)    #为了让大家看得清楚点,我把后两个值都写了出来,这里可以不用写的,因为默认均为false.这里用到了修改器$set,关于修改器我将在以后介绍
> db.name.find()    #参数multi的值是false,只更新找到的第一条纪录
{ "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "li" }
{ "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
{ "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
{ "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
{ "_id" : ObjectId("50592ead955cfb1fd75066cf"), "fname" : "jeff", "lname" : "chen" }
{ "_id" : ObjectId("50592ecb955cfb1fd75066d0"), "fname" : "jeff", "lname" : "zhao" }
{ "_id" : ObjectId("50592edb955cfb1fd75066d1"), "fname" : "jeff", "lname" : "qian" }
> db.name.update({fname:"jeff"},{$set:{lname:"jiang"}},false,true)
> db.name.find()    #参数multi的值是true,更新找到的所有纪录
{ "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
{ "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
{ "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
{ "_id" : ObjectId("50592ead955cfb1fd75066cf"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("50592ecb955cfb1fd75066d0"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("50592edb955cfb1fd75066d1"), "fname" : "jeff", "lname" : "jiang" }
再来看看第三个参数upsert的作用:如果不存在update的纪录,是否插入obj这个新的document。true为插入,默认是false,不插入.
> db.name.update({fname:"jeffery"},{$set:{lname:"jiang"}},false,true)
> db.name.find()  #参数upsert的值是false,不插入
{ "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
{ "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
{ "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
{ "_id" : ObjectId("50592ead955cfb1fd75066cf"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("50592ecb955cfb1fd75066d0"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("50592edb955cfb1fd75066d1"), "fname" : "jeff", "lname" : "jiang" }
> db.name.update({fname:"jeffery"},{$set:{lname:"jiang"}},true,true)
> db.name.find()  #参数upsert的值是true,插入.又学到一种插入数据的方法!
{ "_id" : ObjectId("5059221f955cfb1fd75066cb"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("5059223a955cfb1fd75066cc"), "fname" : "qiang", "lname" : "he" }
{ "_id" : ObjectId("50592245955cfb1fd75066cd"), "fname" : "deng", "lname" : "pan" }
{ "_id" : ObjectId("50592253955cfb1fd75066ce"), "fname" : "guage", "lname" : "zeng" }
{ "_id" : ObjectId("50592ead955cfb1fd75066cf"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("50592ecb955cfb1fd75066d0"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("50592edb955cfb1fd75066d1"), "fname" : "jeff", "lname" : "jiang" }
{ "_id" : ObjectId("5059357ad3ba22406ad408e6"), "fname" : "jeffery", "lname" : "jiang" }

update方法操作其实还是有点复杂的,这里我只简单地介绍了下它的基体操作,复杂的操作是合理利用各种修改器,以达到更高效更方便的管理.关于修改器的使用,我将在以后实验.

您可能感兴趣的文档:

--结束END--

本文标题: MongoDB修改数据update和save方法

本文链接: https://www.lsjlt.com/news/36104.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MongoDB修改数据update和save方法
        前面我简单介绍了下MongoDB怎样插入数据.那么数据插入到数据库中,就可能会修改数据.在MongoDB中,它提供了修改数据的方法:update.下面,我来简单说下up...
    99+
    2022-10-18
  • mysql修改数据运算的方法
    mysql修改数据运算的方法?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!mysql修改数据运算的方法:1、insert语...
    99+
    2022-10-18
  • navicat批量修改数据的方法
    这篇文章主要介绍了navicat批量修改数据的方法,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。navicat是一个非常好用的数据库管理软件,今...
    99+
    2022-10-18
  • phpmyadmin数据库名的修改方法
    小编给大家分享一下phpmyadmin数据库名的修改方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!phpmyadmin是一个以PHP为基础,以Web-Base方式架构在网站主机上的My...
    99+
    2022-10-18
  • navicat修改数据库名的方法
    小编给大家分享一下navicat修改数据库名的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!  有一个数据库,名称为A,需要...
    99+
    2022-10-18
  • sql语句修改数据的方法
    这篇文章主要介绍了sql语句修改数据的方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。sql语句修改数据SQL 中,可以使用 UPDAT&...
    99+
    2022-10-18
  • Pandas DataFrame数据修改值的方法
    dfmi.iloc[:,1] pandas要修改值先需要了解DataFrame的一些知识 此处参照的是pandas的官方文档 When setting values in a pan...
    99+
    2022-11-13
  • 修改mysql数据库名字的方法
    这篇文章主要介绍了修改mysql数据库名字的方法,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。改mysql数据库名称的方法:首先创建目标库;然后...
    99+
    2022-10-18
  • phpmyadmin数据库名称的修改方法
    小编给大家分享一下phpmyadmin数据库名称的修改方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!登录phpmyadmin...
    99+
    2022-10-18
  • hbase修改数据的方法是什么
    HBase提供了两种主要的方法来修改数据: 使用Put操作:Put操作用于新增或更新一行数据。可以通过创建一个Put实例来指定要...
    99+
    2023-10-28
    hbase
  • php修改json数据格式的方法
    小编给大家分享一下php修改json数据格式的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!php有什么用php是一个嵌套的缩写名称,是英文超级文本预处理语言...
    99+
    2023-06-14
  • listview修改数据的方法有哪些
    ListView修改数据的方法有以下几种:1. 直接修改数据源:可以直接通过修改ListView的数据源来实现数据的修改。例如,使用...
    99+
    2023-08-26
    listview
  • Oracle 12C 修改数据库字符集方法+修改客户端字符集方法:
    Oracle 12C 可以进行PDB的单独修改字符集方式,后续介绍。本次采用修改CDB全部修改的方式: 先查询数据库字符集情况: select * from nls_database_parame...
    99+
    2022-10-18
  • mysql数据库表和字段编码的修改方法
    本篇内容介绍了“mysql数据库表和字段编码的修改方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!用lo...
    99+
    2022-10-18
  • phpmyadmin修改数据库用户名和密码的方法
    这篇文章主要介绍了phpmyadmin修改数据库用户名和密码的方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。通过phpMyAdmin 图...
    99+
    2022-10-18
  • Oracle参数的查询和修改方法
    这篇文章主要讲解了“Oracle参数的查询和修改方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Oracle参数的查询和修改方法”吧!测试环境DB Ver...
    99+
    2022-10-18
  • plsql修改表数据的方法有哪些
    在PL/SQL中,修改表数据的方法有以下几种:1. 使用UPDATE语句:可以使用UPDATE语句来修改表中的数据。语法如下:```...
    99+
    2023-10-11
    plsql
  • 阿里云数据库修改编码方法
    本文主要介绍了如何在阿里云数据库中修改编码方法。阿里云数据库提供了多种编码方式,用户可以根据自己的需求选择合适的编码方式。本文将详细介绍如何进行修改,并提供相应的操作步骤和注意事项。 在阿里云数据库中,修改编码方法是非常常见的操作。这是因为...
    99+
    2023-11-04
    阿里 数据库 方法
  • Windows下MySQL数据目录的修改方法
    这篇文章给大家分享的是有关Windows下MySQL数据目录的修改方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。Windows下MySQL数据目录修改的方法:首先停掉MySQ...
    99+
    2022-10-18
  • MySQL数据库修改表结构的方法
    MySQL数据库修改表结构的方法?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!MySQL数据库修改表结构的方法:1、使用a...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作