一、find() 方法以非结构化的方式来显示所有文档。如果你需要以易读的方式来读取数据,可以使用 pretty() 方法,语法格式如下:db.collection_name.find().pretty()

  1、查看数据库下的所有的collection: show collections

    2、查看collection下的数据 db.collection_name.find().pretty()

  MongoDB数据更新可以使用update()函数。在执行remove()函数前先执行find()命令来判断执行的条件是否正确,这是一个比较好的习惯。

> db.user.save({name:"xxxxx",password:"11111"})
WriteResult({ "nInserted" : 1 })
> db.user.find().pretty()
{
"_id" : ObjectId("569476a63a18f4867aecbcd3"),
"name" : "xxxxx",
"password" : "11111"
}
> db.user.remove("name":"xxxxx")
2016-01-12T11:45:41.976+0800 E QUERY [thread1] SyntaxError: missing ) after a
rgument list @(shell):1:21

> db.user.remove({"name":"xxxxx"})
WriteResult({ "nRemoved" : 1 })
>还是没有注意检查括号

3、find()会返回匹配文档的所有列:

> db.user.find().pretty()
{
  "_id" : ObjectId("569476a63a18f4867aecbcd3"),
  "name" : "xxxxx",
  "password" : "11111"
}

4、返回指定字段和_id字段(默认会返回_id字段):

  db.user.find({"name":"xxxxx"},{name:1})

5、返回排除字段以外的所有字段:

  db.user.find({"name":"xxxxx"},{password:0}).pretty()

  所以4中要想不返回_id 字段,排除掉_id 字段即可:db.user.find({"name":"xxxxx"},{name:1, _id:0})

6、另外内嵌文档查询(点表示法):

  > db.tao.find({"SourceInfo.Platform": "Taobao"},{SourceInfo:1}).pretty(){

  "_id" : ObjectId("57467a880f281ce229632257"),
  "SourceInfo" : {
    "Platform" : "Taobao",
    "Link" : "https://item.taobao.com/item.htm?spm=a219r.lm869.14.14.n6XAO5&id=527138809962&ns=1&abbucket=17#detail",
    "Site" : "",
    "SiteID" : "",
    "ProductID" : "527138809962"
  }
}
{
  "_id" : ObjectId("57467ab60f281ce3adbd6b0a"),
  "SourceInfo" : {
    "Platform" : "Taobao",
    "Link" : "https://item.taobao.com/item.htm?spm=a219r.lm869.14.14.n6XAO5&id=527138809962&ns=1&abbucket=17#detail",
    "Site" : "",
    "SiteID" : "",
    "ProductID" : "527138809962"
  }
}

> db.tao.find({"SourceInfo.Platform": "Taobao"},{"SourceInfo.Platform":1}).pretty()
{
  "_id" : ObjectId("57467a880f281ce229632257"),
  "SourceInfo" : {
    "Platform" : "Taobao"
  }
}
{
  "_id" : ObjectId("57467ab60f281ce3adbd6b0a"),
  "SourceInfo" : {
    "Platform" : "Taobao"
  }
}

  7、当内嵌文档变得复杂后,如键的值为内嵌文档的数组,内嵌文档的匹配需要些许技巧,例如使用$elemMatch操作符。

    "SourceInfo" :

      [

    "Platform" : "Taobao",
    "Link" : "https://item.taobao.com/item.htm?spm=a219r.lm869.14.14.n6XAO5&id=527138809962&ns=1&abbucket=17#detail",
    "Site" : "",
    "SiteID" : "",
    "ProductID" : "527138809962"
  ]

> db.tao.find({},{"SourceInfo":{$elemMatch:{"Platform":"Taobao"}}, _id:0}).pretty(),【1】

二、remove()

  在执行remove()函数前先执行find()命令来判断执行的条件是否正确,这是一个比较好的习惯。

> db.user.save({name:"xxxxx",password:"11111"})
  WriteResult({ "nInserted" : 1 })
> db.user.find().pretty()
{
  "_id" : ObjectId("569476a63a18f4867aecbcd3"),
  "name" : "xxxxx",
  "password" : "11111"
}
> db.user.remove("name":"xxxxx")
  2016-01-12T11:45:41.976+0800 E QUERY [thread1] SyntaxError: missing ) after a
  rgument list @(shell):1:21

> db.user.remove({"name":"xxxxx"})
  WriteResult({ "nRemoved" : 1 })
>还是没有注意检查括号

如果你想删除所有数据,可以使用以下方式(类似常规 SQL 的 truncate 命令):

db.user.remove()

三、MongoDB 与 RDBMS Where 语句比较(表格来自http://www.runoob.com/mongodb/mongodb-query.html)

如果你熟悉常规的 SQL 数据,通过下表可以更好的理解 MongoDB 的条件语句查询:

操作 格式 范例 RDBMS中的类似语句
等于 {<key>:<value>} db.col.find({"by":"菜鸟教程"}).pretty() where by = '菜鸟教程'
小于 {<key>:{$lt:<value>}} db.col.find({"likes":{$lt:50}}).pretty() where likes < 50
小于或等于 {<key>:{$lte:<value>}} db.col.find({"likes":{$lte:50}}).pretty() where likes <= 50
大于 {<key>:{$gt:<value>}} db.col.find({"likes":{$gt:50}}).pretty() where likes > 50
大于或等于 {<key>:{$gte:<value>}} db.col.find({"likes":{$gte:50}}).pretty() where likes >= 50
不等于 {<key>:{$ne:<value>}} db.col.find({"likes":{$ne:50}}).pretty() where likes != 50

  1、为admin添加成绩50,

  > db.user.update({"name":"admin"},{$set:{"grade":50}})
    WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
  2、为aaaaaa添加成绩99:
  > db.user.update({"name":"aaaaaaaaa"},{$set:{"grade":99}})
    WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

  3、查询grade大于50的:

> db.user.find({"grade":{$gt:50}}).pretty()
  {
    "_id" : ObjectId("5694714a3a18f4867aecbcd2"),
    "name" : "aaaaaaaaa",
    "password" : "123456",
    "grade" : 99
  }

4、查询成绩大于等于50的:
> db.user.find({"grade":{$gte:50}}).pretty()
  {
  "_id" : ObjectId("56946fba3a18f4867aecbcd1"),
  "name" : "admin",
  "password" : "123456",
  "title" : "admin",
  "grade" : 50
  }

  {
    "_id" : ObjectId("5694714a3a18f4867aecbcd2"),
    "name" : "aaaaaaaaa",
    "password" : "123456",
    "grade" : 99
  }

 -----db.xx.find({group:{$nin:["0",""]}}) 
--- $nin:["0"] 
--- {”Group“:{$ne:”0“}} 
------------------2016-5-26 14:01:50--修改--
    source:【1】mongoDb查询
 

学习mongo系列(四) find().pretty() remove() 查询的更多相关文章

  1. MyBatis系列四 之 智能标签进行查询语句的拼接

    MyBatis系列四 之 智能标签进行查询语句的拼接 使用Foreach进行多条件查询 1.1 foreach使用数组进行多条件查询 在MyBatis的映射文件中进行如下配置 <!--根据数组进 ...

  2. 学习mongo系列(一) win/mac安装 解析 连接

    一.安装mongo数据库 下载链接https://www.mongodb.org/downloads, 在执行如下命令的时候事先按照目录新建如下的目录:(如果数据库安装在D盘就在D盘的根目录下建)&q ...

  3. 小白学习Spark系列四:RDD踩坑总结(scala+spark2.1 sql常用方法)

    初次尝试用 Spark+scala 完成项目的重构,由于两者之前都没接触过,所以边学边用的过程大多艰难.首先面临的是如何快速上手,然后是代码调优.性能调优.本章主要记录自己在项目中遇到的问题以及解决方 ...

  4. 学习mongo系列(九)索引,聚合,复制(副本集),分片

    一.索引 二.聚合 三.复制(副本集) 四.分片 尚未实践操作. 详见http://www.runoob.com/mongodb/mongodb-indexing.html

  5. 学习mongo系列(八)密码与权限

    一.设置密码及用户角色[1] > db.createUser(... {... user: "maxh",... pwd: "123",... roles ...

  6. 学习mongo系列(七)aggregate() ,$group() 管道

    aggregate()聚合,主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果.有点类似sql语句中的 count(*) 接上边的数据库: > db.user.aggregate ...

  7. 学习mongo系列(六)limit(munber),skip(number)

    > db.user.find().pretty(){ "_id" : ObjectId("56946fba3a18f4867aecbcd1"), &quo ...

  8. 学习mongo系列(二) 新建数据库,collection ,insert(),save()

    一,新建数据库user:use user 二,查看当前使用的数据库:db 三,查看所有数据库:show dbs 四,删除当前正在使用的数据库:db.dropDatabase() 五,在当前数据库中插入 ...

  9. oracle学习笔记(四) DQL数据查询语言和TCL 事务控制语言

    DML 数据管理语言 Data manage language insert, update, delete以及select语句,不过,有人也把select单独出来,作为DQL 数据查询语言 data ...

随机推荐

  1. git-配置公司账号

    1.初始化配置 git config --global user.name " abc" git config --global user.email "abc@123. ...

  2. 在C#中获取如PHP函数time()一样的时间戳

    原文:在C#中获取如PHP函数time()一样的时间戳 c#中没有象PHP一样的time()时间戳函数,但有DateTime.Now.Ticks用来计算时间差. 此属性的值为自 0001 年 1 月 ...

  3. Web性能API——帮你分析Web前端性能

    前端性能统计必备api,有不知道的吗? 正文从这开始- 开发一个现代化的互联网网站是一项复杂的任务,需要各种职能的密切合作以应对用户日新月异的需求.其中,网页的性能直接决定了用户的体验,而随着新型客户 ...

  4. Difference between Stored Procedure and Function in SQL Server

    Stored Procedures are pre-compile objects which are compiled for first time and its compiled format ...

  5. 基于docker+etcd+confd + haproxy构建高可用、自发现的web服务

    基于docker+etcd+confd + haproxy构建高可用.自发现的web服务 2016-05-16 15:12 595人阅读 评论(0) 收藏 举报 版权声明:本文为博主原创文章,未经博主 ...

  6. jquery mobile界面数据刷新

    JQM里面当我们更新了某些页面标签(如: listview, radiobuttons, checkboxes, select menus)里的数据时,必须做refresh操作. 为什么必须做refr ...

  7. 如何保存CONSOLE LOG

    很早以前就想过问题,但因为我们一直有自动化程序去做,所以没仔细研究.   今天学习了一下,其实很简单,在sdsf.da 里面搜索master会看到下面这样一个TASK *MASTER* STC0000 ...

  8. Maps for Developers

    苹果官方文档: Give your apps a sense of place with maps and location information. Present maps with custom ...

  9. 【笔记】jquery hover的用法

    hover函数格式: $("A").hover(function(){ //当鼠标移入的时候执行第一个函数 },function(){ //当鼠标移出的时候执行第二个函数 }) * ...

  10. 给jar包进行数字签名(2014-06-28记)

    整理一下两年前用到的一些资料. 为了使Applet或者Java Web Start程序能够访问客户端本地资源,需要对Applet或者JWS程序jar包进行数据签名,当客户端打开Applet或者JWS程 ...