前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Nodejs和Mongodb的连接器Mongoose

Nodejs和Mongodb的连接器Mongoose

作者头像
笔阁
发布2018-09-04 15:56:34
5.8K0
发布2018-09-04 15:56:34
举报
文章被收录于专栏:极客编程极客编程

简介

今天我们将学习Mongoose,什么是Mongoose呢,它于MongoDB又是什么关系呢,它可以用来做什么呢,介绍Mongoose之前,我们先简单了解一下MongoDB。

MongoDB是一个开源的NoSQL数据库,相比MySQL那样的关系型数据库,它更显得轻巧、灵活,非常适合在数据规模很大、事务性不强的场合下使用。同时它也是一个对象数据库,没有表、行等概念,也没有固定的模式和结构,所有的数据以文档的形式存储(文档,就是一个关联数组式的对象,它的内部由属性组成,一个属性对应的值可能是一个数、字符串、日期、数组,甚至是一个嵌套的文档。),数据格式就是JSON。

介绍了MongoDB,我们下面就要认识Mongoose了。

1. Mongoose是什么?

Mongoose是MongoDB的一个对象模型工具,是基于node-mongodb-native开发的MongoDB nodejs驱动,可以在异步的环境下执行。同时它也是针对MongoDB操作的一个对象模型库,封装了MongoDB对文档的的一些增删改查等常用方法,让NodeJS操作Mongodb数据库变得更加灵活简单。

2. Mongoose能做什么?

Mongoose,因为封装了对MongoDB对文档操作的常用处理方法,让NodeJS操作Mongodb数据库变得easy、easy、So easy!

学习了上面的介绍,相信你已经对Mongoose有了初步的认识和了解,千里之行,始于足下,奔跑吧,少年!

安装 引用

前面我们已经认识了Mongoose,也了解了MongoDB,回顾一下:MongoDB是一个对象数据库,是用来存储数据的;Mongoose是封装了MongoDB操作的一个对象模型库,是用来操作这些数据的。

好,下面我们就来进行操作数据的第一步吧。

1. 安装mongoose:

代码语言:javascript
复制
 npm install mongoose

2. 引用mongoose:

代码语言:javascript
复制
 var mongoose = require("mongoose");

3. 使用"mongoose"连接数据库:

代码语言:javascript
复制
 var db = mongoose.connect("mongodb://user:pass@localhost:port/database");

4. 执行下面代码检查默认数据库test,是否可以正常连接成功?

代码语言:javascript
复制
 var mongoose = require("mongoose");  
 var db = mongoose.connect("mongodb://127.0.0.1:27017/test"); 
 db.connection.on("error", function (error) {  console.log("数据库连接失败:" + error); }); 
 db.connection.on("open", function () {  console.log("------数据库连接成功!------"); });

了解集合

通过上节内容的学习我们已经打下了基础,本节内容就开始对MongoDB数据库进行具体操作。首先,我们再次简单介绍一下MongoDB数据库。

MongoDB —— 是一个对象数据库,没有表、行等概念,也没有固定的模式和结构,所有的数据以Document(以下简称文档)的形式存储(Document,就是一个关联数组式的对象,它的内部由属性组成,一个属性对应的值可能是一个数、字符串、日期、数组,甚至是一个嵌套的文档。),后面我们会学习如何创建文档并插入内容。

在MongoDB中,多个Document可以组成Collection(以下简称集合),多个集合又可以组成数据库。

我们想要操作MongoDB数据,那就得先要具备上面所说的包含数据的“文档”,文档又是什么意思呢,请看如下介绍。

文档 —— 是MongoDB的核心概念,是键值对的一个有序集,在JavaScript里文档被表示成对象。同时它也是MongoDB中数据的基本单元,非常类似于关系型数据库管理系统中的行,但更具表现力。

集合 —— 由一组文档组成,如果将MongoDB中的一个文档比喻成关系型数据库中的一行,那么一个集合就相当于一张表。

如果我们要通过Mongoose去创建一个“集合”并对其进行增删改查,该怎么实现呢,到这里我们就要先了解Schema(数据属性模型)、Model、Entity了。

好,下面就开始去深入了解它们吧!

Schema简述

Schema —— 一种以文件形式存储的数据库模型骨架,无法直接通往数据库端,也就是说它不具备对数据库的操作能力,仅仅只是数据库模型在程序片段中的一种表现,可以说是数据属性模型(传统意义的表结构),又或着是“集合”的模型骨架。

那如何去定义一个Schema呢,请看示例:

代码语言:javascript
复制
var mongoose = require("mongoose");
 
var TestSchema = new mongoose.Schema({
 name : { type:String },//属性name,类型为String
 age : { type:Number, default:0 },//属性age,类型为Number,默认为0
 time : { type:Date, default:Date.now },
 email: { type:String,default:''}
});

基本属性类型有:字符串、日期型、数值型、布尔型(Boolean)、null、数组、内嵌文档等。

Model简述

Model —— 由Schema构造生成的模型,除了Schema定义的数据库骨架以外,还具有数据库操作的行为,类似于管理数据库属性、行为的类。

如何通过Schema来创建Model呢,如下示例:

代码语言:javascript
复制
var db = mongoose.connect("mongodb://127.0.0.1:27017/test");  
// 创建Model var TestModel = db.model("test1", TestSchema);

test1:数据库中的集合名称,当我们对其添加数据时如果test1已经存在,则会保存到其目录下,如果未存在,则会创建test1集合,然后在保存数据。

拥有了Model,我们也就拥有了操作数据库的金钥匙,在后面的内容中,我们就会学习使用Model来进行增删改查的具体操作,所以,一定要熟悉他的创建格式哟!

如果你想对某个集合有所作为,那就交给Model模型来处理吧,创建一个Model模型,我们需要指定:1.集合名称,2.集合的Schema结构对象,满足这两个条件,我们就会拥有一个操作数据库的金钥匙。

Entity简述

Entity —— 由Model创建的实体,使用save方法保存数据,Model和Entity都有能影响数据库的操作,但Model比Entity更具操作性。

使用Model创建Entity,如下示例:

代码语言:javascript
复制
 var TestEntity = new TestModel({   
 name : "Lenka",  age : 36,  email: "lenka@qq.com" }); 
 console.log(TestEntity.name); // Lenka 
 console.log(TestEntity.age); // 36

创建成功之后,Schema属性就变成了Model和Entity的公共属性了。

创建集合

基于前面的内容,接下来我们就开始学习对数据的具体操作了,下面是关于一些基础数据的定义,相信对于你来说已经不陌生了,请在仔细温习一遍吧!

为了方便后面内容的学习和提高您的学习效率,以下基础数据均和后面内容紧密相连,所以必须按照以下结构方式来定义,请勿修改(默认数据库为test,集合为test1)。

代码语言:javascript
复制
 var mongoose = require("mongoose");  
 var db = mongoose.connect("mongodb://127.0.0.1:27017/test"); 
 var TestSchema = new mongoose.Schema({  
     name : { type:String },  
     age : { type:Number, default:0 },  
     email: { type:String },  
     time : { type:Date, default:Date.now } 
     });
 var TestModel = db.model("test1", TestSchema ); 
 var TestEntity = new TestModel({  
     name : "helloworld",  
     age : 28,  
     email: "helloworld@qq.com" 
     }); 
 TestEntity.save(function(error,doc){  
 if(error){  
    console.log("error :" + error);  
    }
 else{  
    console.log(doc);  } 
 });
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015/10/13 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 简介
  • 安装 引用
  • 了解集合
  • Schema简述
  • Model简述
  • Entity简述
  • 创建集合
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档