Mongoose入门

简介

Mongoose是MongoDB的对象模型工具。nodejs和mongodb结合的主要原因是有相同的数据存储格式JSON,在应用层使用具有非常好的连续性,无需太多的代码用来进行数据转换等工作。

就像PHP和JAVA连接Mysql一样,nodejs连接mongodb也需要有驱动driver。mongodb的driver还是有一些的,其中最著名的就是native driver: https://github.com/mongodb/node-mongodb-native, 该项目由mongodb的创建公司10gen进行维护,它提供了一些基础的连接和数据操作的API。

今天我们说的mongoose其实是在mongodb-native之上的一个封装,使得我们对于数据的操作是建立在模型的基础上。Mongoose有一些关键概念:

  1. Schema(模式): 一种以文件形式存储的数据库模型骨架,不具备数据库的操作能力
  2. Model(模型): 由Schema发布生成的模型,具有抽象属性和行为的数据库操作对
  3. Entity(实体): 由Model创建的实体,他的操作也会影响数据库

它们之间的关系是:Schema生成ModelModel创造EntityModelEntity都可对数据库操作造成影响,但ModelEntity更具操作性。

基本操作

创建连接

var mongoose =require('mongoose');//引用mongoose模块
mongoose.connect('mongodb://localhost/test');//连接数据库
//或者
var db = mongoose.createConnection('localhost','test');
db.once('open',function(){
     //一次打开记录
});

定义Schema

var userSchema = new mongoose.Schema({
  name: {
  first: String,
  last: { type: String, trim: true }
  },
  age: { type: Number, min: 0}
});

将Schema发布为Model

var PUser = mongoose.model('PowerUsers', userSchema);

使用Model创建Entity

var johndoe = new PUser ({
  name: { first: 'John', last: '  Doe   ' },
  age: 25
});

保存Entity到数据库

johndoe.save(function (err) {if (err) console.log ('Error on save!')});

查询

PUser.find({}).exec(function(err, result) {
  if (!err) {
    // handle result
  } else {
    // error handling
  };
});

查询的语法为:

Model.find(query, fields, options, callback);

其中 Model 为 Mongoose 模型对象。

query参数与 MongoDB 查询条件一致。

fields 指定查询的键。

options 选项,有 limit, skip, populate 等。

callback 则是回调函数,查询完毕后执行。该回调函数支持传入两个参数,分别为 err 和 result。

 

更多使用方法参考官方文档: http://mongoosejs.com/docs/guide.html

转载于:https://www.cnblogs.com/cubika/p/3501887.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Node.js环境下,使用Mongoose可以方便地进行对MongoDB的增删改操作。首先,需要导入Mongoose数据库连接配置文件,在该配置文件中,使用`mongoose.connect`方法连接到MongoDB数据库。然后,定义一个模型(Model),模型是根据数据结构定义的类,用于操作数据库中的集合。模型需要定义一个Schema来规定数据的结构。在Schema中,可以定义字段的类型、默认值等。最后,通过模型的方法,可以对数据库进行增删改操作。 增加数据: 要在数据库中增加一条数据,首先需要创建一个模型实例,并设置数据的属性,然后调用`save`方法进行保存。 删除数据: 要删除数据库中的数据,可以使用模型的`deleteOne`或`deleteMany`方法。可以根据条件指定要删除的数据。 修改数据: 要修改数据库中的数据,首先要根据条件查询到对应的数据,然后修改数据的属性,最后调用`save`方法进行保存。 以上是Node.js中使用Mongoose进行数据库的增删改操作的基本流程。具体的代码可以参考示例代码和Mongoose的官方文档进行更详细的了解和实践。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Node.js 高级篇(三):Mongoose 增删改查](https://blog.csdn.net/qq_41887214/article/details/123947394)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [mongoose 入门(一) mongoose 实现数据 的增、删、改、查、默认参数 、模块化](https://blog.csdn.net/qq_41880073/article/details/122895427)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值