mongodb中save方法

前面我简单介绍了下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" }

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,386评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,142评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,704评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,702评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,716评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,573评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,314评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,230评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,680评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,873评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,991评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,706评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,329评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,910评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,038评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,158评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,941评论 2 355

推荐阅读更多精彩内容