安装mongoose
npm i mongoose -g
查看所有文档
表名.find()/表名.findOne()
增加文档
new 表名({属性名1:属性值1,属性名2:属性值2...}).save(function(err,ret){...})
删除文档
表名.remove()
修改文档
根据条件更新所有
表名.update(id,new data,callback)
根据某一条件更新一条数据
表名.findOneAndUpdate(conditions,doc,[options],[calllback])
根据id更新指定id的那一条数据
表名.findByIdAndUpdate(id, new value ,callback)
例:
var mongoose = require('mongoose')
//链接MongoDB数据库
mongoose.connect('mongodb://localhost/test', { useNewParser: true })
mongoose.Promise = global.Promise;
//设计cat数据库模型,model(表名,数据结构)
var Cat = mongoose.model('Cat', { name: String });
for (var i = 0; i <= 5; i++) {
//实例化一个cat
var kitty = new Cat({ name: '哈比' + i })
//持久化保存实例对象
kitty.save(function (err) {
if (err) {
console.log(err);
} else {
console.log('我是哈比');
}
})
}
结果:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-q356tcSk-1575896007592)(D:/itcast/myself/%E5%B0%B1%E4%B8%9A%E7%8F%AD/day06/mongoose-demo/demo1.jpg)]
例二:
var mongoose = require('mongoose')
var schema = mongoose.Schema
mongoose.connect('mongodb://localhost/test')
//新建一个博客数据结构,规定约束
var blogSchema = new schema({
tittle:{
type:String,//数据类型为字符串
required:true//必填
},
author:String,
body:String,
comments:[{body:String,date:Date}],
data:{type:Date,default:Date.now},
hidden:Boolean,
meta:{
votes:Number,
favs:Number
}
})
//mongoose.model(大写名词单数字符串,结构schema)
//用来发布架构为model。mongoose会自动根据参数1生成小写复数集合名称。例如User-->users
//返回值为构造函数
//有了这个构造函数之后就可以对集合(表)中的数据增删改查等操作了
var Blog = mongoose.model('Blog',blogSchema)
//新增文档(一条数据)
// var myBlog = new Blog({
// tittle:"在node中使用MongoDB",
// auto:"Jason",
// body:"balabalabala...",
// comments:[{body:"好!!",data:2019-8-30}]
// })
// myBlog.save(function(err,ret){
// if (err) {
// console.log("保存失败");
// }else{
// console.log("保存成功");
// console.log(ret);
// }
// })
//删除文档(一条数据)
// Blog.remove({
// tittle:"在node中使用MongoDB"
// },function (err,ret) {
// if (err) {
// console.log("删除失败");
// }else{
// console.log("删除成功");
// console.log(ret);
// }
// })
//修改文档(数据)
// Blog.findByIdAndUpdate('5d68e5b066ff713690668fd5', {
// comments: [{ body: "你叭叭啥呢??", date: 2019 - 8 - 30 }]
// }, function (err, ret) {
// if (err) {
// console.log("更新失败");
// console.log(err);
// } else {
// console.log("更新成功");
// console.log(ret);
// }
// })
//查询数据
//1.查询所有,返回值为数组
// Blog.find(function (err, ret) {
// if (err) {
// console.log('查询失败')
// } else {
// console.log(ret)
// }
// })
// //2.按条件查询
// Blog.find({
// tittle: 'hello mongoose'
// }, function (err, ret) {
// if (err) {
// console.log('查询失败')
// } else {
// console.log(ret)
// }
// })
//返回查询匹配到的第一个对象
Blog.findOne({
tittle: 'hello mongoose'
}, function (err, ret) {
if (err) {
console.log('查询失败')
} else {
console.log(ret)
}
})
增加和删除数据结果
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RXSijLOr-1575896007594)(D:/itcast/myself/%E5%B0%B1%E4%B8%9A%E7%8F%AD/day06/mongoose-demo/增加和删除数据.jpg)]
修改结果
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bCaPYiMN-1575896007597)(D:/itcast/myself/%E5%B0%B1%E4%B8%9A%E7%8F%AD/day06/mongoose-demo/%E4%BF%AE%E6%94%B9%E6%95%B0%E6%8D%AE.jpg)]