zoukankan      html  css  js  c++  java
  • MongoDB之二(增删查改)

    一: Insert操作

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

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

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

       

        ①  单条插入

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

    示例:

    var single={"name":"net","password":"12345","age":30,"address":{"province":"anhui","city":"beijing"},"favourite":["apple","banana"]}
    db.user.insert(single)

     ② 批量插入

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

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

    二:Find操作

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

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

         ②:And,OR,In,NotIn

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

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

    /* find age>28 */
    db.user.find({"age":{$gt:28}})
    /* find age<28 */
    db.user.find({"age":{$lt:28}})

    /* find age!28 */
    db.user.find({"age":{$ne:28}})

    /* find age==30 */
    db.user.find({"age":30})

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

    /*find name='java' && province='anhui'*/
    db.user.find({"name":"java","address.province":"anhui"})

    /*find province in ["anhui","guangdong"]*/
    db.user.find({"address.province":{$in:["anhui","guangdong"]}})

    /*find province not in ["anhui","guangdong"]*/
    db.user.find({"address.province":{$nin:["anhui","guangdong"]}})

     

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

    /*find name startwith 'n' and endwith 't' */
    db.user.find({"name":/^n/,"name":/t$/})

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

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

    示例:

    /* find name='net' */
    db.user.find({$where:function(){return this.name='net'}})

    三:Update操作

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

        <1> 整体更新

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

     示例:

    /*update java age=29*/
    var model=db.user.findOne({"name":"java"})
    model.age=29
    db.user.update({"name":"java"},model)
    db.user.find()

    <2> 局部更新

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

       修改器: $inc 和 $set。

     ①  $inc修改器

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

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

    示例:

    /*add java age +30 */
    db.user.update({"name":"java"},{$inc:{"age":30}})
    db.user.find()

    ② $set修改器

    示例:

    /*add java age=10 */
    db.user.update({"name":"java"},{$set:{"age":10}})
    db.user.find()

     <3> upsert操作

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

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

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

     示例:

    /*update for add */
    db.user.update({"name":"javac"},{$inc:{"age":1}},true)

    db.user.find()

    <4> 批量更新

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

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

    四: Remove操作

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

  • 相关阅读:
    Go语言类型(布尔、整型、数组、切片、map等)
    CSS学习系列2 -- CSS中的清除浮动
    CSS学习系列1
    Umbraco中根据ID获取IPublishedContent
    Umbraco -- 在Visual Studio中新建一个View 如何在Umbraco back office 中显示出来
    Umbraco back office 中templates显示不出来问题解决 (一片空白)
    JavaScript学习系列5 ---ES6中的var, let 和const
    JavaScript学习系列4 ----- JavaScript中的扩展运算符 三个点(...)
    JavaScript学习系列3 -- JavaScript arguments对象学习
    .NET中的泛型委托
  • 原文地址:https://www.cnblogs.com/duanxz/p/4388546.html
Copyright © 2011-2022 走看看