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

2012-02-19 10:06

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

by 一线码农

at 2012-02-19 02:06:00

original http://www.cnblogs.com/huangxincheng/archive/2012/02/19/2357846.html

<p>看过上一篇,相信大家都会知道如何开启mongodb了,这篇就细说下其中的增删查改,首先当我们用上一篇同样的方式打开mongodb,突然</p> <p>傻眼了,擦,竟然开启不了,仔细观察&ldquo;划线区域&ldquo;的信息,发现db文件夹下有一个类似的&rdquo;lock file&rdquo;阻止了mongodb的开启,接下来我们要做的就</p> <p>是干掉它,之后,开启成功,关于mongodb的管理方式将在后续文章分享。</p> <p><img src="http://pic002.cnblogs.com/images/2012/214741/2012021822210512.png" alt="" /></p> <p></p> <p>一: Insert操作</p> <p>上一篇也说过,文档是采用&ldquo;K-V&rdquo;格式存储的,如果大家对JSON比较熟悉的话,我相信学mongodb是手到擒来,我们知道JSON里面Value</p> <p>可能是&ldquo;字符串&rdquo;,可能是&ldquo;数组&rdquo;,又有可能是内嵌的一个JSON对象,相同的方式也适合于BSON。</p> <p>常见的插入操作也就两种形式存在:&ldquo;单条插入&rdquo;和&ldquo;批量插入&rdquo;。</p> <p></p> <p>① &nbsp;单条插入</p> <p>先前也说了,mongo命令打开的是一个javascript shell。所以js的语法在这里面都行得通,看起来是不是很牛X。&nbsp; &nbsp; &nbsp;&nbsp;</p> <p><img src="http://pic002.cnblogs.com/images/2012/214741/2012021823382560.png" alt="" /></p> <p>② 批量插入</p> <p>这玩意跟&ldquo;单条插入&rdquo;的差异相信大家应该知道,由于mongodb中没有提供给shell的&ldquo;批量插入方法&rdquo;,没关系,各个语言的driver都打通</p> <p>了跟mongodb内部的批量插入方法,因为该方法是不可或缺的,如果大家非要模拟下批量插入的话,可以自己写了for循环,里面就是insert。</p> <p></p> <p>二:Find操作</p> <p>日常开发中,我们玩查询,玩的最多的也就是二类:</p> <p>①: &gt;, &gt;=, &lt;, &lt;=, !=, =。</p> <p>②:And,OR,In,NotIn</p> <p>这些操作在mongodb里面都封装好了,下面就一一介绍:</p> <p>&lt;1&gt;"$gt", "$gte", "$lt", "$lte", "$ne", "没有特殊关键字",这些跟上面是一一对应的,举几个例子。</p> <p><img src="http://pic002.cnblogs.com/images/2012/214741/2012021823495458.png" alt="" width="825" height="280" /></p> <p></p> <p>&lt;2&gt; "无关键字&ldquo;, "$or", "$in","$nin" 同样我也是举几个例子</p> <p></p> <p><img src="http://pic002.cnblogs.com/images/2012/214741/2012021900175533.png" alt="" width="813" height="300" /></p> <p></p> <p>&lt;3&gt; 在mongodb中还有一个特殊的匹配,那就是&ldquo;正则表达式&rdquo;,这玩意威力很强的。</p> <p><img src="http://pic002.cnblogs.com/images/2012/214741/2012021900232833.png" alt="" /></p> <p></p> <p>&lt;4&gt; 有时查询很复杂,很蛋疼,不过没关系,mongodb给我们祭出了大招,它就是$where,为什么这么说,是因为$where中的value</p> <p>就是我们非常熟悉,非常热爱的js来助我们一马平川。</p> <p><img src="http://pic002.cnblogs.com/images/2012/214741/2012021900575333.png" alt="" /></p> <p></p> <p>三:Update操作</p> <p>更新操作无非也就两种,整体更新和局部更新,使用场合相信大家也清楚。</p> <p>&lt;1&gt; 整体更新</p> <p>不知道大家可还记得,我在上一篇使用update的时候,其实那种update是属于整体更新。</p> <p><img src="http://pic002.cnblogs.com/images/2012/214741/2012021901222512.png" alt="" /></p> <p></p> <p>&lt;2&gt; 局部更新</p> <p>有时候我们仅仅需要更新一个字段,而不是整体更新,那么我们该如何做呢?easy的问题,mongodb中已经给我们提供了两个</p> <p>修改器: $inc 和 $set。</p> <p>① &nbsp;$inc修改器</p> <p>$inc也就是increase的缩写,学过sql server 的同学应该很熟悉,比如我们做一个在线用户状态记录,每次修改会在原有的基础上</p> <p>自增$inc指定的值,如果&ldquo;文档&rdquo;中没有此key,则会创建key,下面的例子一看就懂。</p> <p><img src="http://pic002.cnblogs.com/images/2012/214741/2012021901321851.png" alt="" /></p> <p></p> <p>② $set修改器</p> <p>啥也不说了,直接上代码&nbsp;</p> <p><img src="http://pic002.cnblogs.com/images/2012/214741/2012021901370591.png" alt="" /></p> <p></p> <p>&lt;3&gt; upsert操作</p> <p>这个可是mongodb创造出来的&ldquo;词&rdquo;,大家还记得update方法的第一次参数是&ldquo;查询条件&rdquo;吗?,那么这个upsert操作就是说:如果我</p> <p>没有查到,我就在数据库里面新增一条,其实这样也有好处,就是避免了我在数据库里面判断是update还是add操作,使用起来很简单</p> <p>将update的第三个参数设为true即可。</p> <p><img src="http://pic002.cnblogs.com/images/2012/214741/2012021901495450.png" alt="" /></p> <p></p> <p>&lt;4&gt; 批量更新</p> <p>在mongodb中如果匹配多条,默认的情况下只更新第一条,那么如果我们有需求必须批量更新,那么在mongodb中实现也是很简单</p> <p>的,在update的第四个参数中设为true即可。例子就不举了。</p> <p></p> <p>四: Remove操作</p> <p>这个操作在上一篇简单的说过,这里就不赘述了。</p><img src="http://www.cnblogs.com/huangxincheng/aggbug/2357846.html?type=1" width="1" height="1" alt=""/><p><a href="http://www.cnblogs.com/huangxincheng/archive/2012/02/19/2357846.html" target="_blank">本文链接</a></p>