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之间的
相关推荐
mongodb学习笔记资料,从安装到操作库collection 对document的crud 索引 replicaSet sharding 备份与恢复
自己在学习MongoDB的一些笔记,里面有各个查询选择器的使用截图,还有一些索引的介绍。
查询是数据库操作的基础,MongoDB使用find()方法进行数据查询,可配合不同的查询条件进行精确筛选。除了基本查询外,还可以通过运算符进行高级查询,包括比较运算符($gt、$gte、$lt、$lte等)、逻辑运算符($ne、$...
MongoDB 学习笔记 本文档是 MongoDB 学习笔记,涵盖了 NoSQL、Cache、运行平台等多个方面的知识点。 一、NoSQL 数据库 MongoDB MongoDB 是一个强大、灵活、可扩展性好的文档数据存储器,可以完成大部分关系数据库...
mongodb学习笔记 MongoDB 是一个基于分布式文件存储的开源数据库系统,主要用于处理大量数据的存储和查询。以下是 MongoDB 的一些基本操作和技巧: 插入文档 MongoDB 中可以使用 `insert` 方法来插入文档,例如 ...
首先,`mongodb_and_python`学习笔记可能涵盖了如何使用Python编程语言与MongoDB进行交互。Python是常见的MongoDB驱动程序之一,通过PyMongo库,开发者可以方便地执行CRUD(创建、读取、更新、删除)操作,构建复杂...
MongoDB 是一种流行的开源、非关系型数据库系统,以其灵活性、高性能和易用性而备受开发者青睐。在本文中,我们将深入探讨 ...在实际项目中,学习和掌握 MongoDB 及其驱动程序能够帮助你更好地应对现代数据存储需求。
本压缩包“mongoDB学习笔记及工具.zip”包含了一些资源,帮助你深入理解和掌握MongoDB的相关知识。 1. **笔记(note.txt)**: 这个文件可能是对MongoDB的基础概念、安装过程、基本操作和进阶特性的详细记录。笔记...
在MongoDB中,索引对于优化查询性能至关重要,尤其在处理大量数据时。下面将详细介绍MongoDB中不同类型的索引创建、查询及维护。 首先,MongoDB有一个默认的`_id`字段,它扮演着主键的角色。每个集合在创建时都会...
总结的MongoDB的学习笔记,基本上包括了MongoDB的方方面面,每个知识点,都有示例代码,有需要的朋友,可以下载下来进一步补充完善。
### MongoDB 学习笔记知识点详解 #### 一、MongoDB 命令行基础操作 **1.1 帮助命令** - **help**:显示 MongoDB shell 的基本帮助信息。 - **db.help()**:提供当前数据库的帮助信息。 - **db.mycoll.help()**:...
以下是对MongoDB学习的一些关键知识点的详细解释: 1. **MongoDB的基本概念**:MongoDB以集合(Collections)的形式存储数据,集合相当于关系型数据库中的表。集合内包含文档(Documents),文档是JSON格式的数据...
在读取文件时,系统首先根据查询条件在`fs.files`中找到相应的文件记录,获取文件ID,然后在`fs.chunks`中查找所有与该ID匹配的chunk,按照`n`字段的顺序读取数据并合并,从而恢复原始文件内容。 然而,使用GridFS...
1. **数据库概念**:数据库是存储和管理数据的系统,根据需求提供数据查询。MongoDB是一种NoSQL数据库,不遵循传统的关系型数据库模式,因此没有固定的表结构。 2. **SQL vs. NoSQL**:SQL数据库如Oracle和MySQL...