`
bit1129
  • 浏览: 1070068 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

【MongoDB学习笔记七】MongoDB数据查询

 
阅读更多

 MongoDB和SQL查询语句对比

 查询的功能  SQL  MongoDB
 查询全部记录  select * from people

 db.people.find()

 查询age<=34的记录 select * from people where age <=34

db.people.find({"age":{$le:34}})

查询age=34的记录 select * from people where age =34

db.people.find({"age":34})

查询指定列(投影) select age,name from people db.people.find({},{"age":1, "name":1})
指定条件查询指定列(投影) select age,name from people where age = 34 db.people.find({"age":34},{"age":1, "name":1})
查询结果排序 select * from people order by name db.people.find().sort({"name":1})
模糊查询(正则表达式) select * from people where name like 'Jac*' db.people.find({"name":/^Jac/})
限制和跳过 select * from people limit 10 skip 20 db.people.find().limit(10).skip(20)
或查询 select * from people where age = 30 or name = 'Jack' db.people.find({$or:[{'age':30},{'name':'Jack}]})
Top 1 select * from people limit 1 db.people.findOne()
查询计划 explain select * from people where age <=34 db.people.find({"age":{$le:34}}).explain();
 记录总数  select(1) from people  db.people.find().count()
 记录总数 select count(age) from people  db.people.find({"age":{$exists:true}}).count();
多列去重查询  select distinct age from people

 db.person.distinct("age");

返回的是个整型数组

多列去重查询 select distinct age,name from people

TBD

 

find

db.people.find(第一个参数JSON,第二个参数JSON);  //第一个参数指定查询条件,第二个参数指定投影的列

 

 

投影查询

db.people.find({},{"age":0});//0表示此属性在查询结果中不出现,其它都出现
db.people.find({},{"age":1,"name":1}); //1表示此属性出现,这条查询表示name和age出现,其它不出现。实际上_id属性如果不指定,则默认表示出现
db.people.find({},{"age":0,"name":1}); //报错,0和1不能混合出现,You cannot currently mix including and excluding fields
db.people.find({},{"_id":0"age":1,"name":1});//name和age出现,_id不出现。_id是唯一一个可以和普通字段including和excluding混合出现的属性

 


MongoDB元算符

 

 

条件查询-1

db.people.find({"age":{$gt:27,$le:32}});//等价于SQL查询:select * from people where age > 27 and age <= 32 

 

条件查询-2

 

db.people.find({"age":{$not:{$in:[28,29,30,31]}}}) //查找年龄不在28和31之间的
 

条件查询-3

 

db.people.find({"age":{$mod:[5,1]}}); //查找age%5=1的

 

条件查询-4-正则表达式

 

db.people.find({"name":/^Clo/); //name以Clo开头的文档

 

条件查询-5-数组查询

 

db.people.find({"friends.name":"Jack"});//friends数组中的元素有个name属性

db.people.find({"friends.name":{$in:["Jack","Mike"]}}); //friends数组中的元素有个name属性包含Jack或者Mike

 

条件查询-6-数组长度查询

 

 

db.people.find({friends:{$size: 1}});  //查询friends数组长度为1的文档

 

 条件查询-7-$where

 

 $where条件查询可以自己定义查询的处理逻辑以人实现复杂的查询

 

db.people.find($where,function() { //找出年龄比朋友的年龄都大的文档
   var curItem = this;
   
   if (this.friends) {
   	if (this.age) {
          var friends = this.friends;
          for (var friend in friends) {
           if (friend.age) {
             if (friend.age > this.age) {
	     return false;
             }
           }
          }
         return true;
        }
       return false;
   }
  return false;
})

 

 

 

 

 

 

 

  • 大小: 112.7 KB
分享到:
评论

相关推荐

    mongodb学习笔记资料

    mongodb学习笔记资料,从安装到操作库collection 对document的crud 索引 replicaSet sharding 备份与恢复

    MongoDB学习笔记

    自己在学习MongoDB的一些笔记,里面有各个查询选择器的使用截图,还有一些索引的介绍。

    MongoDB学习笔记思维导图.pdf

    查询是数据库操作的基础,MongoDB使用find()方法进行数据查询,可配合不同的查询条件进行精确筛选。除了基本查询外,还可以通过运算符进行高级查询,包括比较运算符($gt、$gte、$lt、$lte等)、逻辑运算符($ne、$...

    Mongodb学习笔记.docx

    MongoDB 学习笔记 本文档是 MongoDB 学习笔记,涵盖了 NoSQL、Cache、运行平台等多个方面的知识点。 一、NoSQL 数据库 MongoDB MongoDB 是一个强大、灵活、可扩展性好的文档数据存储器,可以完成大部分关系数据库...

    mongodb学习笔记

    mongodb学习笔记 MongoDB 是一个基于分布式文件存储的开源数据库系统,主要用于处理大量数据的存储和查询。以下是 MongoDB 的一些基本操作和技巧: 插入文档 MongoDB 中可以使用 `insert` 方法来插入文档,例如 ...

    mongodb学习笔记和mongodb权威指南

    首先,`mongodb_and_python`学习笔记可能涵盖了如何使用Python编程语言与MongoDB进行交互。Python是常见的MongoDB驱动程序之一,通过PyMongo库,开发者可以方便地执行CRUD(创建、读取、更新、删除)操作,构建复杂...

    MongoDB学习笔记1

    MongoDB 是一种流行的开源、非关系型数据库系统,以其灵活性、高性能和易用性而备受开发者青睐。在本文中,我们将深入探讨 ...在实际项目中,学习和掌握 MongoDB 及其驱动程序能够帮助你更好地应对现代数据存储需求。

    mongoDB学习笔记及工具.zip

    本压缩包“mongoDB学习笔记及工具.zip”包含了一些资源,帮助你深入理解和掌握MongoDB的相关知识。 1. **笔记(note.txt)**: 这个文件可能是对MongoDB的基础概念、安装过程、基本操作和进阶特性的详细记录。笔记...

    MongoDB学习笔记(六) MongoDB索引用法和效率分析

    在MongoDB中,索引对于优化查询性能至关重要,尤其在处理大量数据时。下面将详细介绍MongoDB中不同类型的索引创建、查询及维护。 首先,MongoDB有一个默认的`_id`字段,它扮演着主键的角色。每个集合在创建时都会...

    MongoDB学习笔记思维导图

    总结的MongoDB的学习笔记,基本上包括了MongoDB的方方面面,每个知识点,都有示例代码,有需要的朋友,可以下载下来进一步补充完善。

    MongoDB_学习笔记

    ### MongoDB 学习笔记知识点详解 #### 一、MongoDB 命令行基础操作 **1.1 帮助命令** - **help**:显示 MongoDB shell 的基本帮助信息。 - **db.help()**:提供当前数据库的帮助信息。 - **db.mycoll.help()**:...

    MongoDB学习总结笔记

    以下是对MongoDB学习的一些关键知识点的详细解释: 1. **MongoDB的基本概念**:MongoDB以集合(Collections)的形式存储数据,集合相当于关系型数据库中的表。集合内包含文档(Documents),文档是JSON格式的数据...

    MongoDB学习笔记之GridFS使用介绍

    在读取文件时,系统首先根据查询条件在`fs.files`中找到相应的文件记录,获取文件ID,然后在`fs.chunks`中查找所有与该ID匹配的chunk,按照`n`字段的顺序读取数据并合并,从而恢复原始文件内容。 然而,使用GridFS...

    MongoDB数据库学习笔记

    1. **数据库概念**:数据库是存储和管理数据的系统,根据需求提供数据查询。MongoDB是一种NoSQL数据库,不遵循传统的关系型数据库模式,因此没有固定的表结构。 2. **SQL vs. NoSQL**:SQL数据库如Oracle和MySQL...

Global site tag (gtag.js) - Google Analytics