当前位置:澳门贵宾厅 > 澳门贵宾厅 > 在安装过程中需要特别www.vip8888.com,这个命令会安装mongoose并将其作为项目的依赖
在安装过程中需要特别www.vip8888.com,这个命令会安装mongoose并将其作为项目的依赖
2020-04-29

时间: 2019-12-16阅读: 69标签: 优化

安装使用Mongoose配合Node.js操作MongoDB的基础教程,mongoosemongodb

安装mongoose

使用express准备一个TestMongoDB项目,命令序列如下:

express TestMongoDB
cd TestMongoDB
npm install

执行完上面的命令后,使用下面的命令安装mongoose:

npm install mongoose --save

这个命令会安装mongoose并将其作为项目的依赖,而mongoose依赖的MongoDB driver以及regexp等等模块也会被自动安装。

实例

使用mongoose可以新建数据库、新建集合、对集合内的文档进行CRUD操作,在写代码时,可以对照着mongo shell验证结果是否符合预期。

在TestMongoDB下新建一个mongo.js文件,内容如下:

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/accounts');
var db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'));
db.once('open', function() {
 console.log('mongoose opened!');
 var userSchema = new mongoose.Schema({
   name:{type: String, unique: true}, 
   password:String
  }, 
  {collection: "accounts"}
  );
 var User = mongoose.model('accounts', userSchema);

 User.findOne({name:"WangEr"}, function(err, doc){
  if(err) console.log(err);
  else console.log(doc.name + ", password - " + doc.password);
 });

 var lisi = new User({name:"LiSi", password:"123456"});
 lisi.save(function(err, doc){
  if(err)console.log(err);
  else console.log(doc.name + ' saved');
 }); 
});

上面的文件,直接执行“node mongo.js”命令即可查看效果。

要使用mongoose,先require,然后使用connect方法连接数据库。connect原型:

connect(uri, options, [callback])

uri的格式类似:“mongodb://user:[email protected]:port/database”。

mongoose的connection对象定义了一些事件,比如connected、open、close、error等,我们可以监听这些事件。

在我们的示例代码里,我监听了open事件,在回调函数中,定义了Schema,调用mongoose.model来编译Schema得到Model对象。需要注意的是,定义Schema时指定的collection名字与mongoose.model的第一参数要保持一致。

拿到了Model对象,就可以执行增删改查等操作了。Model对象有find()、findOne()、update()、remove()等方法,和我们在mongo shell里的用法类似。这些方法都有一个可选的callback,当你提供这些callback时,执行的结果会通过这个callback返回给你。如果你不提供,这些方法会返回一个Query对象,你可以再通过Query组装新的选项,然后调用Query的exec(callback)来提交查询。

我在代码里查找WangEr的档案时用了callback,没用Query。

Model对象有个Model(doc)方法,用来构造一个文档(Document)。创建Lisi的文档时就是这种Document对象的save()方法可以将文档保存到数据库。
通过mongoose进行的基本操作:
1、增

var obj = new Movie();
obj.title = '标题一';
obj.content = '内容';
obj.save(function(err) {

});

2、删

Movie.remove({
  _id:id
},function (err) {

})

3、改

Movie.update({
  _id:id
},json,{},function (err) {

})

4、查

Movie.findOne({
  _id: id
}, function(err, obj) {

});
Movie.find({}).sort({_id: -1}).limit(3).exec(function(err, obj) {

})

本篇文章结合前文《Node学习笔记 Mongodb和Mongoose》对curd示例进行优化

您可能感兴趣的文章:

安装mongoose 使用express准备一个TestMongoDB项目,命令序列如下: express TestMongoD...

MongoDB 安装

安装文件下载地址:[-center/community]

Windows 平台安装 MongoDB:-window-install.html

在安装过程中需要特别注意,需要将Install MongoDB Compass前默认的勾选取消

可以使用mongod --version命令查看 MongoDB 版本,若版本号输出正常则安装完毕

Mongoose 安装和配置

npm install mongoose

优化student.js文件

有了Mongoose的帮助可以极大的简化数据的增、删、改、查工作

首先,配置 Mongoose

var mongoose = require('mongoose'); // 引入 mongoosemongoose.connect('mongodb://localhost/test'); // 通过 mongoose 连接 mongodb 数据库

其次,设计Schema数据结构

var mongoose = require('mongoose'); // 引入 mongoosemongoose.connect('mongodb://localhost/test'); // 通过 mongoose 连接 mongodb 数据库// 设计数据结构var Schema = mongoose.Schemavar studentData = new Schema({ // 实例化 Schema name: { // 姓名 type: String, // 数据类型 String required: true // 数据为必填项 }, gender: { // 性别 type: Number, // 数据类型 Number default: 0, // 数据默认值 enum: [0, 1] // 可枚举数据 }, age: { // 年龄 type: Number // 数据类型 Number },})

最后,导出Student

module.exports= mongoose.model('Student', studentData)// 将数据保存 Mongodb 数据库 Student 集合中// 导出 Mongodb 数据

到此为止,student.js优化完毕

优化router.js文件

对于router.js文件,我们只需要调用mongoose提供的增、删、改、查 API 既可

代码如下:

var Student = require('./student') // 引入 student.js (student 模块专职用于处理数据)var express = require('express') // 引入 expressvar router = express.Router() // 创建路由容器// 将所有路由都挂在到 router 路由容器中router.get('/', function (req, res) { // 渲染学生列表页面// .find() 用于从数据库中查询所有数据,接收一个函数参数 // function (err, students) 接收两个参数,其一为错误信息,二为查询的数据 students Student.find(function (err, students) { if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500 return res.status(500).send('Server error.') } res.render('index.html', { // 响应返回学生列表页面 students: students }) })})router.get('/new', function (req, res) { // 渲染添加学生页面 res.render('new.html')})router.post('/new', function (req, res) { // 处理添加学生 // new Student(req.body) 新建一条数据 // .save 用于将数据添加到数据库,接收一个函数参数 // function (err) 参数用于接收错误信息 new Student(req.body).save(function (err) { if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500 return res.status(500).send('Server error.') } res.redirect('/') // 页面重定向回首页 })})router.get('/edit', function (req, res) { // 渲染编辑学生页面 // .findById() 用于根据 id 查询一条数据,接收两个参数,其一为匹配数据,二为函数 // function (err, student) 函数接收两个参数,其一为错误信息,二为查询数据结果 // req.query.id.replace(/"/g, '') 为需查询的数据 id ,通过 .replace 将 id 字符串转化为数字类型 Student.findById(req.query.id.replace(/"/g, ''), function (err, student) { if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500 return res.status(500).send('Server error.') } res.render('edit.html', { // 响应返回编辑学生页面 student: student }) })})router.post('/edit', function (req, res) { // 处理编辑学生 // .findByIdAndUpdate() 用于根据 id 更新数据,接收三个参数,其一为匹配数据,二为需替换的数据,三为函数 // function (err) 函数接收错误信息 // req.body.id.replace(/"/g, '') 为需查询的数据 id ,通过 .replace 将 id 字符串转化为数字类型 var id = req.body.id.replace(/"/g, '') Student.findByIdAndUpdate(id, req.body, function (err) { if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500 return res.status(500).send('Server error.') } res.redirect('/') // 页面重定向回首页 })})router.get('/students/delete', function (req, res) { // 处理删除学生 // .findByIdAndRemove() 用于根据 id 删除对应数据,接收两个参数,其一为匹配数据,二为函数 // function (err) 函数接收错误信息 // req.body.id.replace(/"/g, '') 为需查询的数据 id ,通过 .replace 将 id 字符串转化为数字类型 var id = req.query.id.replace(/"/g, '') Student.findByIdAndRemove(id, function (err) { if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500 return res.status(500).send('Server error.') } res.redirect('/') // 页面重定向回首页 })})module.exports = router // 导出 router

文章已同步我的个人博客:《Node学习笔记 优化crud增删改查》

下一篇:没有了