• 转载: 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  
  • 相关阅读:
    selenium 的页面对象模型Page Object
    PostMan的在线安装和简单使用
    用Jmeter对数据库执行压力测试
    常用的Linux系统命令
    摘:《自动化测试技术领航》
    WEB接口测试之Jmeter接口测试自动化 (四)(持续构建)
    WEB接口测试之Jmeter接口测试自动化 (二)(数据分离)
    WEB接口测试之Jmeter接口测试自动化 (一)(初次接触)
    性能测试篇 :Jmeter监控服务器性能
    UI自动化测试篇 :ReportNG替代TestNG自带html版测试报告初探
  • 原文地址:https://www.cnblogs.com/BOSET/p/7069249.html
Copyright © 2020-2023  润新知