1.使用官方的MongoDB
包来操作
http://mongodb.github.io/node-mongodb-native/
2.使用第三方包mongoose
来操作MongoDB数据库
第三方包:mongoose
基于MongoDB官方的mongodb
包再一次做了封装,名字叫mongoose
,是WordPress项目团队开发的。
https://mongoosejs.com/
3.学习指南(步骤)
官方学习文档:https://mongoosejs.com/docs/index.html
3.1 设计Scheme 发布Model (创建表)
// 引包
// 引包后才能require使用
var mongoose = require('mongoose');
// 拿到schema图表
var Schema = mongoose.Schema;
// 连接数据库
// 指定连接数据库后不需要存在,当你插入第一条数据库后会自动创建数据库
mongoose.connect('mongodb://localhost/test');
// 设计集合结构(表结构)
// 用户表
var userSchema = new Schema({
username: {
type: String,
require: true //添加约束,保证数据的完整性,让数据按规矩统一
},
password: {
type: String,
require: true
},
email: {
type: String
}
});
// 将文档结构发布为模型
var User = mongoose.model('User', userSchema);
3.2 添加数据(增)
// 通过模型构造函数对User中的数据进行操作
var user = new User({
username: 'chen',
password: '123456',
email: 'xiaochen@qq.com'
});
user.save(function(err, ret) {
if (err) {
console.log('保存失败');
} else {
console.log('保存成功');
console.log(ret);
}
});
3.3 删除(删)
根据条件删除所有:
User.remove({
username: 'chen'
}, function(err, ret) {
if (err) {
console.log('删除失败');
} else {
console.log('删除成功');
console.log(ret);
}
});
根据条件删除一个:
Model.findOneAndRemove(conditions,[options],[callback]);
根据id删除一个:
User.findByIdAndRemove(id,[options],[callback]);
3.4 更新(改)
更新所有:
User.remove(conditions,doc,[options],[callback]);
根据指定条件更新一个:
User.FindOneAndUpdate([conditions],[update],[options],[callback]);
根据id更新一个:
// 更新 根据id来修改表数据
User.findByIdAndUpdate('此处为需要选择的id', {
username: 'chenchen'
}, function(err, ret) {
if (err) {
console.log('更新失败');
} else {
console.log('更新成功');
}
});
3.5 查询(查)
查询所有:
// 查询所有
User.find(function(err,ret){
if(err){
console.log('查询失败');
}else{
console.log(ret);
}
});
条件查询所有:
// 根据条件查询
User.find({ username:'cbj' },function(err,ret){
if(err){
console.log('查询失败');
}else{
console.log(ret);
}
});
条件查询单个:
// 按照条件查询单个,查询出来的数据是一个对象({})
// 没有条件查询使用findOne方法,查询的是表中的第一条数据
User.findOne({
username: 'cbj'
}, function(err, ret) {
if (err) {
console.log('查询失败');
} else {
console.log(ret);
}
});