一、介紹
Mongoose是一個對象文檔模型庫,官網:http://www.mongoosejs.net/
二、作用
方便使用代碼操作Mongodb數據庫
三、使用流程
//1. 安裝 mongoose
//2. 導入 mongoose
const mongoose = require('mongoose');
//3. 連接數據庫
mongoose.connect('mongodb://127.0.0.1:27017/bilibili');
//4. 設置連接回調
//連接成功
mongoose.connection.on('open', () => {console.log('連接成功');//5. 創建文檔結構對象let BookSchema = new mongoose.Schema({title: String,author: String,price: Number});//6. 創建文檔模型對象let BookModel = mongoose.model('book', BookSchema);//7. 插入文檔BookModel.create({title: '西游記',author: '吳承恩',price: 19.9}, (err, data) => {if (err) throw err;//輸出 data 對象console.log(data);//8. 斷開連接mongoose.disconnect();});
});
//連接出錯
mongoose.connection.on('error', () => {console.log('連接出錯~~');
})
//連接關閉
mongoose.connection.on('close', () => {console.log('連接關閉');
})
四、字段類型
類型 | 描述 |
String | 字符串 |
Number | 數字 |
Boolean | 布爾值 |
Array | 數組,也可以使用 [] 來標識 |
Date | 日期 |
Buffer | Buffer 對象 |
Mixed | 任意類型,需要使用 mongoose.Schema.Types.Mixed 指定 |
ObjectId | 對象 ID,需要使用 mongoose.Schema.Types.ObjectId 指定 |
Decimal128 | 高精度數字,需要使用 mongoose.Schema.Types.Decimal128 指定 |
五、字段驗證
Mongoose 有一些內建驗證器,可以對字段值進行驗證
5.1 必填項
title: {
type: String,
required: true // 設置必填項
}
5.2?默認值
author: {
type: String,
default: '匿名' //默認值
},
5.3 枚舉項
gender: {
type: String,
enum: ['男','女'] //設置的值必須是數組中的
},
5.5?唯一值
username: {
type: String,
unique: true
},
六、CURD
數據庫的基本操作包括四個,增加(create),刪除(delete),修改(update),查(read)
6.1?增加
插入一條
SongModel.create({title: '給我一首歌的時間',author: 'Jay'
}, function(err, data) {//錯誤console.log(err);//插入后的數據對象console.log(data);
});
插入多條
PhoneModel.insertMany([{brand: '華為',color: '灰色',price: 2399,tags: ['電量大', '屏幕大', '信號好']},{brand: '小米',color: '白色',price: 2099,tags: ['電量大', '屏幕大', '信號好']}
], (err, data) => {if (err) throw err;console.log('寫入成功');mongoose.connection.close();
})
6.2?刪除
刪除一條數據
SongModel.deleteOne({_id: '5dd65f32be6401035cb5b1ed'
}, function(err) {if (err) throw err;console.log('刪除成功');mongoose.connection.close();
});
刪除多條
SongModel.deleteMany({author: 'Jay'
}, function(err) {if (err) throw err;console.log('刪除成功');mongoose.connection.close();
});
6.3?更新
//更新一條數據 第一個參數是需要更新的對象,第二個參數是要更新的字段BookModel.updateOne({name:'秋園'},{price:8}).then(res=>{console.log(res)})//更新多條BookModel.updateMany({author:'余華'},{is_hot:false}).then(res=>{console.log(res)})
6.4?查詢
SongModel.findOne({author: '王力宏'
}, function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});
//根據 id 查詢數據
SongModel.findById('5dd662b5381fc316b44ce167', function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});
//不加條件查詢
SongModel.find(function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});
//加條件查詢 第一個參數是查詢條件
SongModel.find({author: '王力宏'
}, function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});
七、條件控制
7.1?運算符
在 mongodb 不能 > < >= <= !== 等運算符,需要使用替代符號
- > 使用 $gt
- < 使用 $lt
- >= 使用 $gte
- <= 使用 $lte
- !== 使用 $ne
db.students.find({id:{$gt:3}}); id號比3大的所有的記錄
?7.2?邏輯運算
$or 邏輯或的情況
//查找年齡為18或者24的學生
db.students.find({$or:[{age:18},{age:24}]});
$and 邏輯與的情況
//查找年齡大于15并且小于20的學生
db.students.find({$and: [{age: {$lt:20}}, {age: {$gt: 15}}]});
7.3?正則匹配
條件中可以直接使用 JS 的正則語法,通過正則可以進行模糊查詢
db.students.find({name:/imissyou/});
八、個性化讀取
8.1?字段篩選
//0:不要的字段
//1:要的字段
SongModel.find().select({_id: 0,title: 1
}).exec(function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});
8.2?數據排序
//sort 排序
//1:升序
//-1:倒序
SongModel.find().sort({hot: 1
}).exec(function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});
8.3?數據截取
//skip 跳過 limit 限定
SongModel.find().skip(10).limit(10).exec(function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});