设为首页 收藏本站
查看: 1047|回复: 0

[经验分享] 让NodeJS更容易操作Mongodb数据库

[复制链接]

尚未签到

发表于 2015-7-7 10:19:30 | 显示全部楼层 |阅读模式
Mongoose是什么



Mongoose是什么
  Mongoose是MongoDB的一个对象模型工具,可以工作于异步环境下。
  定义一个模型很容易:

varComments=newSchema({
title     :String, body      :String, date      :Date});varBlogPost=newSchema({
author    :ObjectId, title     :String, body      :String, date      :Date, comments  :[Comments], meta      :{
votes :Number, favs  :Number}});
mongoose.model('BlogPost',BlogPost);
安装
  推荐通过NPM方式安装:

$ npm install mongoose
  或者,你可以从Github仓库中获取代码,然后解压:

$ 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)定义的,如:

varSchema= mongoose.Schema,ObjectId=Schema.ObjectId;varBlogPost=newSchema({
author    :ObjectId, title     :String, body      :String, date      :Date});
  除了定义文档结构和你要存储的数据类型外,模式(Schema)还用于以下定义:
  



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

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

varComment=newSchema({
name  :{ type:String,default:'hahaha'}, age   :{ type:Number, min:18, index:true}, bio   :{ type:String, match:/[a-z]/}, date  :{ type:Date,default:Date.now }});// 定义setterComment.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();
instance.my.key ='csser';
instance.save(function(err){//});
  或者我们也可以从同样的的集合(collection)中找到文档(documents):

myModel.find({},function(err, docs){// docs.forEach});
  也可以调用findOne, findById, update等等方法,更多的细节请阅读 API文档 。

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

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

// 重新获得模型varBlogPost= mongoose.model('BlogPost');// 创建一篇博客日志var post =newBlogPost();// 创建一个评论
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)中间件定义如下:

.pre(method,function(next){// ...})
  当每个中间件调用下一个时,它们按顺序执行。
  并行(Parallel)中间件提供更细粒度的控制,其定义如下:

.pre(method,function(next,done){// ...})
  Parallel 中间件可以立刻next(),但是只有当所有parallel中间件调用done()之后最后的参数才被执行。

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

schema.pre('save',function(next){// 发生了一些错误next(newError('有错误发生'));});// 接着...
myModel.save(function(err){// 错误可以来自某个中间件});
API 文档
  可以在 http://mongoosejs.com 找到相关API文档。
  转自:http://www.csser.com/board/4f3f516e38a5ebc9780004fe
  http://www.csser.com/board/4f4e92dbeb0defac5700011e

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-84034-1-1.html 上篇帖子: nodejs操作mongodb 下篇帖子: nodejs mongodb 查询要看的文章
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表