## 數據查詢
**基本查詢**
* 方法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登陸完善