## 数据查询
**基本查询**
* 方法find():查询
~~~
db.集合名称.find({条件文档})
~~~
* 方法findOne():查询,只返回第一个
~~~
db.集合名称.findOne({条件文档})
~~~
* 方法pretty():将结果格式化
~~~
db.集合名称.find({条件文档}).pretty()
~~~
## 比较运算符
* 等于,默认是等于判断,没有运算符
* 小于$lt
* 小于或等于$lte
* 大于$gt
* 大于或等于$gte
* 不等于$ne
* 例1:查询名称等于'gj'的学生
~~~
db.stu.find({name:'gj'})
~~~
* 例2:查询年龄大于或等于18的学生
~~~
db.stu.find({age:{$gte:18}})
~~~
**逻辑运算符**
* 查询时可以有多个条件,多个条件之间需要通过逻辑运算符连接
* 逻辑与:默认是逻辑与的关系
* 例3:查询年龄大于或等于18,并且性别为1的学生
~~~
db.stu.find({age:{$gte:18},gender:1})
~~~
* 逻辑或:使用$or
* 例4:查询年龄大于18,或性别为0的学生
~~~
db.stu.find({$or:[{age:{$gt:18}},{gender:1}]})
~~~
* and和or一起使用
* 例5:查询年龄大于18或性别为0的学生,并且学生的姓名为gj
~~~
db.stu.find({$or:[{age:{$gte:18}},{gender:1}],name:'gj'})
~~~
**范围运算符**
* 使用"$in","$nin" 判断是否在某个范围内
* 例6:查询年龄为18、28的学生
~~~
db.stu.find({age:{$in:[18,28]}})
~~~
**支持正则表达式**
* 使用//或$regex编写正则表达式
* 例7:查询姓黄的学生
~~~
db.stu.find({name:/^黄/})
db.stu.find({name:{$regex:'^黄'}}})
~~~
**自定义查询**
* 使用$where后面写一个函数,返回满足条件的数据
* 例7:查询年龄大于30的学生
~~~
db.stu.find({$where:function(){return this.age>20}})
~~~
- mysql
- 1.创建库和表
- 1.1.数据库简介
- 1.2.安装管理
- 1.3.数据完整性
- 1.4.命令脚本操作
- 2.查询
- 2.1.条件
- 2.2.聚合
- 2.3.分组
- 2.4.排序
- 2.5.分页
- 3.高级
- 3.1.关系
- 3.2.连接
- 3.3.自关联
- 3.4.子查询
- 3.5.内置函数
- 3.6.视图
- 3.7.事务
- 4.与python交互
- 4.1.交互类型
- 4.2.增改删
- 4.3.查询
- 4.4.封装
- 4.5.用户登录
- Nosql简介
- mongodb
- 1.基本操作
- 1.1.环境安装
- 1.2.数据库操作
- 1.3.集合操作
- 1.4.数据类型
- 1.5.数据操作
- 1.6.数据查询
- 1.6.1.Limit与Skip
- 1.6.2.投影
- 1.6.3.排序
- 1.6.4.统计个数
- 1.6.5.消除重复
- 2.高级操作
- 2.1.聚合aggregate
- 2.1.1.$group
- 2.1.2.$match
- 2.1.3.$project
- 2.1.4.$sort
- 2.1.5.$limit,$skip
- 2.1.6.$unwind
- 2.2.安全
- 2.3.复制(副本集)
- 2.4.备份和恢复
- 2.5.与python交互
- redis
- 1.基本配置
- 2.数据操作
- 2.1.string
- 2.2.键命令
- 2.3.hash
- 2.4.list
- 2.5.set
- 2.6.zset
- 4.高级
- 4.1.发布订阅
- 4.2.主从配置
- 5.与python交互
- 6.login登陆完善