Mongoose – 让NodeJS更容易操作Mongodb数据库

本文介绍了Mongoose,MongoDB的对象模型工具,详细讲解了如何安装、连接数据库、定义及使用模型,并提供了中间件和错误处理的示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Mongoose是什么

Mongoose是MongoDB的一个对象模型工具,可以工作于异步环境下。

定义一个模型很容易:

var Comments = new Schema({ title : String , body : String , date : Date }); var BlogPost = new Schema({ author : ObjectId , title : String , body : String , date : Date , comments : [Comments] , meta : { votes : Number , favs : Number } }); mongoose.model('BlogPost', BlogPost);

安装

推荐通过NPM方式安装。

$ npm install mongoose

或者,你可以从仓库中获取代码,然后解压:

$ git clone git@github.com:LearnBoost/mongoose.git support/mongoose/
// 将模块添加至NodeJS可以找到的环境路径中 require.paths.unshift('support/mongoose/lib');

然后就可以在应用中将mongoose模块包含进来

require('mongoose');

连接到MongoDB数据库

首先,我们需要定义一个连接。如果你的应用只使用一个数据库,可以使用mongoose.connect,如果需要创建附加连接,使用mongoose.createConnection。

connect和createConnection都接受mongodb数据库连接,支持URI或者参数(host,database,port)的形式。

var mongoose = require('mongoose'); mongoose.connect('mongodb://www.csser.com/csser.com_database');

连接一旦建立成功,该连接实例的open事件就被触发。如果你使用的是mongoose.connect方式,连接对象为mongoose.connection;否则,mongoose.createConnection返回的是Connection对象。

切记!Mongoose在与数据库真正建立连接之前便缓存了所有的命令,这就意味着你在定义模型、执行查询时不必非要确认与MongoDB数据库的连接是否已经建立。(一回@CSSer注:异步是MongoDB等与传统数据库的重大区别)

定义模型

模型是通过模式接口(Schema interface)定义的

var Schema = mongoose.Schema , ObjectId = Schema.ObjectId; var BlogPost = new Schema({ author : ObjectId , title : String , body : String , date : Date });

除了定义文档结构和你要存储的数据类型外,模式(Schema)还用于以下定义:

  • Validators (异步和同步)
  • Defaults
  • Getters
  • Setters
  • Indexes – 索引
  • Middleware – 中间件
  • Methods definition – 方法定义
  • Statics definition – 静态定义
  • Plugins – 插件

下面的代码向我们展示了这些功能的一部分:

var Comment = new Schema({ name : { type: String, default: 'hahaha' } , age : { type: Number, min: 18, index: true } , bio : { type: String, match: /[a-z]/ } , date : { type: Date, default: Date.now } }); // 定义setter Comment.path('name').set(function (v) { return v.capitalize(); }); // 定义中间件 Comment.pre('save', function (next) { notify(this.get('email')); next(); });

你可以查看几乎包含所有模型定义的示例

访问模型

当通过mongoose.model(‘ModelName’, mySchema)定义了一个模型之后,我们可以通过相同的函数来访问它

var myModel = mongoose.model('ModelName');

接下来我们可以将模型的实例保存下来:

var instance = new myModel(); myModel.my.key = 'csser'; myModel.save(function (err) { // });

或者我们也可以从相同的集合(collection)中找到文档(documents)

myModel.find({}, function (err, docs) { // docs.forEach });

也可以调用findOne, findById, update等等,更多的细节请阅读API文档

嵌入文档

还记得在第一个示例的代码片段中,我们在模式中定义了一个键(key):

comments: [Comments]

这里的Comments是我们已经创建的模式(Schema),这就是说创建嵌入文档跟下面的代码看起来一样简单:

// 重新获得模型 var BlogPost = mongoose.model('BlogPost'); // 创建一篇博客日志 var post = new BlogPost(); // 创建一个评论 post.comments.push({ title: 'My comment for csser.com' }); post.save(function (err) { if (!err) console.log('Success!'); });

用同样的方式删除模式

BlogPost.findById(myId, function (err, post) { if (!err) { post.comments[0].remove(); post.save(function (err) { // do something }); } });

嵌入文档拥有与模型相同的功能,Defaults、validators、middleware。当发生错误时,它会冒泡到save()错误回调函数,这里错误处理是一个单元。

Mongoose interacts with your embedded documents in arrays atomically, out of the box.

中间件

中间件是Mongoose 1.0推出的最激动人心的功能之一,它让我们可以不用再受嵌套回调函数的折磨了。

中间件定义在模式级别(Schema level),当方法初始化时生效(当文档与MongoDB数据初始化后),然后保存(当文档或嵌入文档保存后)。

中间件有两种类型,它们由定义的函数签名确定(即函数接受的参数)。

Serial Serial 中间件定义如下:

.pre(method, function (next) { // ... })

当每个中间件调用下一个时,它们按顺序执行。

Parallel Parallel 中间件提供更细粒度的控制,其定义如下:

.pre(method, function (next, done) { // ... })

Parallel 中间件可以立刻next(),但是最后的参数(done)会在所有parallel中间件调用完后才被执行。

错误处理

如果任一个中间件调用next或done时抛出了错误,执行流会中断,错误会被作为参数传入回调函数。

例如:

schema.pre('save', function (next) { // 发生了一些错误 next(new Error('有错误发生')); }); // 接着... myModel.save(function (err) { // 错误可以来自某个中间件 });

API 文档

可以在 http://mongoosejs.com 找到相关API文档。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值