8天学通MongoDB——第二天 细说增删查改

  看过上一篇,相信大家都会知道如何开启mongodb了,这篇就细说下其中的增删查改,首先当我们用上一篇同样的方式打开mongodb,突然

傻眼了,擦,竟然开启不了,仔细观察“划线区域“的信息,发现db文件夹下有一个类似的”lock file”阻止了mongodb的开启,接下来我们要做的就

是干掉它,之后,开启成功,关于mongodb的管理方式将在后续文章分享。

 

一: Insert操作

     上一篇也说过,文档是采用“K-V”格式存储的,如果大家对JSON比较熟悉的话,我相信学mongodb是手到擒来,我们知道JSON里面Value

可能是“字符串”,可能是“数组”,又有可能是内嵌的一个JSON对象,相同的方式也适合于BSON。

      常见的插入操作也就两种形式存在:“单条插入”和“批量插入”。

   

    ①  单条插入

          先前也说了,mongo命令打开的是一个javascript shell。所以js的语法在这里面都行得通,看起来是不是很牛X。      

    

   ② 批量插入

      这玩意跟“单条插入”的差异相信大家应该知道,由于mongodb中没有提供给shell的“批量插入方法”,没关系,各个语言的driver都打通

了跟mongodb内部的批量插入方法,因为该方法是不可或缺的,如果大家非要模拟下批量插入的话,可以自己写了for循环,里面就是insert。

 

二:Find操作

     日常开发中,我们玩查询,玩的最多的也就是二类:

     ①: >, >=, <, <=, !=, =。

     ②:And,OR,In,NotIn

这些操作在mongodb里面都封装好了,下面就一一介绍:

    <1>"$gt", "$gte", "$lt", "$lte", "$ne", "没有特殊关键字",这些跟上面是一一对应的,举几个例子。

   

<2> "无关键字“, "$or", "$in","$nin" 同样我也是举几个例子

 

  

<3> 在mongodb中还有一个特殊的匹配,那就是“正则表达式”,这玩意威力很强的。

 

<4> 有时查询很复杂,很蛋疼,不过没关系,mongodb给我们祭出了大招,它就是$where,为什么这么说,是因为$where中的value

  就是我们非常熟悉,非常热爱的js来助我们一马平川。

 

三:Update操作

      更新操作无非也就两种,整体更新和局部更新,使用场合相信大家也清楚。

    <1> 整体更新

         不知道大家可还记得,我在上一篇使用update的时候,其实那种update是属于整体更新。

  

   

  <2> 局部更新

        有时候我们仅仅需要更新一个字段,而不是整体更新,那么我们该如何做呢?easy的问题,mongodb中已经给我们提供了两个

   修改器: $inc 和 $set。

   ①  $inc修改器

       $inc也就是increase的缩写,学过sql server 的同学应该很熟悉,比如我们做一个在线用户状态记录,每次修改会在原有的基础上

    自增$inc指定的值,如果“文档”中没有此key,则会创建key,下面的例子一看就懂。

 

 ② $set修改器

      啥也不说了,直接上代码 

 

 <3> upsert操作

     这个可是mongodb创造出来的“词”,大家还记得update方法的第一次参数是“查询条件”吗?,那么这个upsert操作就是说:如果我

没有查到,我就在数据库里面新增一条,其实这样也有好处,就是避免了我在数据库里面判断是update还是add操作,使用起来很简单

将update的第三个参数设为true即可。

  

 <4> 批量更新

     在mongodb中如果匹配多条,默认的情况下只更新第一条,那么如果我们有需求必须批量更新,那么在mongodb中实现也是很简单

的,在update的第四个参数中设为true即可。例子就不举了。

 

四: Remove操作

      这个操作在上一篇简单的说过,这里就不赘述了。

分类:  MongoDB
41
0
关注我
« 上一篇: 8天学通MongoDB——第一天 基础入门
» 下一篇: 8天学通MongoDB——第三天 细说高级操作
posted @  2012-02-19 02:06  一线码农 阅读( 98027) 评论( 32编辑  收藏

  
#1楼 2012-02-19 08:18  @清道夫   
周末都不好生休息下,半夜出文章,注意身体哦
  
#2楼 2012-02-19 13:02  jiangchuanzhuan1   
注意身体哦,爱美整形美容www.mls169.com
  
#3楼 2012-02-19 13:33  牛腩   
支持一下。
  
#4楼 [ 楼主2012-02-19 13:35  一线码农   
@ 大龄码农老邓
这话说的我好感动啊,谢谢。
  
#5楼 [ 楼主2012-02-19 13:36  一线码农   
@ jiangchuanzhuan1
谢谢支持,不过广告嫌疑。
  
#6楼 [ 楼主2012-02-19 13:38  一线码农   
@ 牛腩
呵呵,有没有优越感啊?
  
#7楼 2012-02-19 22:22  倚楼无语F5   
lz 打的双引号太多了。 :)
  
#8楼 [ 楼主2012-02-20 10:29  一线码农   
@ 倚楼无语F5
呵呵,我改,谢谢提醒。
  
#9楼 2012-02-20 15:21  今晚打小鸡   
加油啊。好评
  
#10楼 2012-02-20 17:31  今晚打小鸡   
有像分页那样的查询吗,就是我只查询出10-20条记录
  
#11楼 [ 楼主2012-02-20 18:37  一线码农   
@ 今晚打小鸡
谢谢支持
  
#12楼 [ 楼主2012-02-20 18:38  一线码农   
@ 今晚打小鸡
这些操作将在下一篇分享
  
#13楼 2012-02-22 12:15  anhuiLife   
哥们 是 安徽的 呵呵……
  
#14楼 2012-03-30 09:19  鸟寅   
我想请教你一个问题,我现在在做一个mongoDB的查询分析器,我发现这个EVAL方法,不是想象中的使用,你能给我提供一些帮助吗?Eval里面要怎么写?
1
2
3
4
5
6
7
8
9
10
11
12
public  string  GetData( string  currentDb,  string  text)
         {
             using  ( var  mongo =  new  Mongo(_connectionString))
             {
                 mongo.Connect();
                 var  db = mongo.GetDatabase(currentDb);
                 var  doc = db.Eval(text);
                 //var sdsd = ((MongoDatabase)db).SendCommand(text);
                 mongo.Disconnect();
                 return  doc.Values.ToString();
             }
         }
  
#15楼 2012-04-01 17:25  key yao   
您好,看了之后觉得很有收获,谢谢~
我是新手,想问您一下在mongo这个nosql数据库中怎样做到多表连接查询?尤其是所查询的数据不止一条时,希望您有时间的话可以予以解答,谢谢~
  
#16楼 2012-10-18 14:00  规格严格-功夫到家   
真的不错,学习了
  
#17楼 2012-11-05 11:07  hillan   
1
2
3
4
var  persons =  new  Array()
persons[0] = { name :  'zhangsan' , age : 22 }
persons[1] = { name :  'lisi' , age : 33 }
db.person.insert(persons)
  
#18楼 2013-08-06 11:49  luseike   
关注一下,刚接触这中数据库,有点意思,LZ也很给力,顺带问句LZ安徽人?
  
#19楼 2013-08-06 23:24  aplixy   
每一个行业都有一些值得称道的东西,如果说IT行业什么最伟大的话,我相信应该是这种无私奉献的精神,因为我们始终保持一颗年轻的心
  
#20楼 2013-11-14 14:53  风之约   
楼主你好,为什么我用mongoose插入的数据在mongo命令下
db.myDB.find()下查不出数据来?
mongoose的model里是可以find()出数据的
不明白呀~~~
  
#21楼 2014-01-14 14:41  疯狂的老爹   
非常的不错,虽然mongodb比较简单,但是楼主的教程图文并茂,写得非常好。
  
#22楼 2014-08-13 15:24  nickycookie   
<4> 批量更新

在mongodb中如果匹配多条,默认的情况下只更新第一条,那么如果我们有需求必须批量更新,那么在mongodb中实现也是很简单

的,在update的第四个参数中设为true即可。例子就不举了。

这个你试下,会报错的
  
#23楼 2014-10-24 20:13  无西lc   
写正则表达式的时候有错哦
{"name":/^j/, "name":/e&/}, 这样做的话后面的name会覆盖前面的。对不对?
  
#24楼 2015-02-05 20:42  YouYaInsist   
从前竟不知道你会这个,看样子你会的东西还真多。向你看齐。我只能慢慢蜗牛一般爬!
  
#25楼 2015-03-15 11:33  wpttree   
为啥我没有nuclean shut down detected????
  
#26楼 2015-07-20 11:28  xythree   
<3> upsert操作 那里错了,是$set 不是 $inc
  
#27楼 2015-08-13 11:47  todaytoday   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值