Mongoose好处

  • 可以为文档创建一个模式结构(Schema) 可以对模型中的对象/文档进行验证
  • 数据可以通过类型转换转换为对象模型
  • 可以使用中间件来应用业务逻辑挂钩
  • 比Node原生的MongoDB驱动更容易

Mongoose提供的新对象

– Schema(模式对象) 对象定义约束了数据库中的文档结构

– Model 对象作为集合中的所有文档的表示,相当于MongoDB数据库中的集合collection

– Document 表示集合中的具体文档,相当于集合中的一个具体的文档

下载安装

  • npm i mongoose --save

基本用法

//引入
var mongoose = require("mongoose");
//连接数据库
mongoose.connect("mongodb://127.0.0.1/mongoose_test" , { useNewUrlParser: true, useUnifiedTopology:true}); mongoose.connection.once("open",function(){
console.log("--> 数据库连接成功");
}); mongoose.connection.once("close",function(){
console.log("--> 数据库连接已经断开");
}); //断开数据库连接
//mongoose.disconnect(); //将mongoose.Schema 赋值给一个变量
var Schema = mongoose.Schema; //创建Schema(模式)对象
var stuSchema = new Schema({ name:String,
age:Number,
gender:{
type:String,
default:"female"
},
address:String }); //通过Schema来创建Model
//Model代表的是数据库中的集合,通过Model才能对数据库进行操作
//mongoose.model(modelName, schema):
//modelName 就是要映射的集合名 mongoose会自动将集合名变成复数
var StuModel = mongoose.model("student" , stuSchema); /*
- 有了Model,我们就可以来对数据库进行增删改查的操作了 Model.create(doc(s), [callback])
- 用来创建一个或多个文档并添加到数据库中
- 参数:
doc(s) 可以是一个文档对象,也可以是一个文档对象的数组
callback 当操作完成以后调用的回调函数 查询的:
Model.find(conditions, [projection], [options], [callback])
- 查询所有符合条件的文档 总会返回一个数组
Model.findById(id, [projection], [options], [callback])
- 根据文档的id属性查询文档
Model.findOne([conditions], [projection], [options], [callback])
- 查询符合条件的第一个文档 总和返回一个具体的文档对象 conditions 查询的条件
projection 投影 需要获取到的字段
- 两种方式
{name:1,_id:0}
"name -_id"
options 查询选项(skip limit)
{skip:3 , limit:1}
callback 回调函数,查询结果会通过回调函数返回
回调函数必须传,如果不传回调函数,压根不会查询 */
//增:StuModel.create(doc, function(err){});
StuModel.create({
name:"张三",
age:16,
address:"北京"
},function (err) {
if(!err){
console.log("插入成功");
}
}); //查
StuModel.find({},"name age -_id", {skip:3 , limit:1} , function (err , docs) {
if(!err){
console.log(docs);
}
}); /*
修改
Model.update(conditions, doc, [options], [callback])
Model.updateMany(conditions, doc, [options], [callback])
Model.updateOne(conditions, doc, [options], [callback])
- 用来修改一个或多个文档
- 参数:
conditions 查询条件
doc 修改后的对象
options 配置参数
callback 回调函数
Model.replaceOne(conditions, doc, [options], [callback])
* */
StuModel.updateOne({name:"张三"},{$set:{age:20}},function (err) {
if(!err){
console.log("修改成功");
}
}); /*
删除:
Model.remove(conditions, [callback])
Model.deleteOne(conditions, [callback])
Model.deleteMany(conditions, [callback])
*/
StuModel.remove({name:"李四"},function (err) {
if(!err){
console.log("删除成功");
}
}); /*
Model.count(conditions, [callback])
- 统计文档的数量的
*/
StuModel.count({},function (err , count) {
if(!err){
console.log(count);
}
}); //创建一个Document
var stu = new StuModel({
name:"奔波霸",
age:48,
gender:"male",
address:"碧波潭"
});
stu.save(function (err) {
if(!err){
console.log("保存成功~~~");
}
}); StuModel.findOne({},function (err , doc) {
if(!err){
/*
update(update,[options],[callback])
- 修改对象
remove([callback])
- 删除对象 */
//console.log(doc);
/*doc.update({$set:{age:28}},function (err) {
if(!err){
console.log("修改成功~~~");
}
});*/ /*doc.age = 18;
doc.save();*/ /*doc.remove(function (err) {
if(!err){
console.log("大师兄再见~~~");
}
});*/ /*
get(name)
- 获取文档中的指定属性值
set(name , value)
- 设置文档的指定的属性值
id
- 获取文档的_id属性值
toJSON() ******
- 转换为一个JSON对象 toObject()
- 将Document对象转换为一个普通的JS对象
转换为普通的js对象以后,注意所有的Document对象的方法或属性都不能使用了 */
//console.log(doc.get("age"));
//console.log(doc.age); //doc.set("name","猪小小");
//doc.name = "hahaha"; //console.log(doc._id);
//var j = doc.toJSON();
//console.log(j); //var o = doc.toObject(); //console.log(o); doc = doc.toObject(); delete doc.address; console.log(doc._id); }
});

创建Schema模式对象

var userSchema = new Schema(definition, option);
  • options常用选项

    • autoIndex 布尔值,开启自动索引,默认true

    • bufferCommands 布尔值,缓存由于连接问题无法执行的语句,默认true

    • capped 集合中最大文档数量

    • collection 指定应用Schema的集合名称

    • id 布尔值,是否有应用于_id的id处理器,默认true

    • _id 布尔值,是否自动分配id字段,默认true

    • strict 布尔值,不符合Schema的对象不会被插入进数据库,默认true
  • 定义Schema模式对象
    • 模式为集合中的文档定义字段和字段类型。
    • 对于在模式中的每个字段,你都需要定一个特定的值类

      型。受支持的类型如下:

      • String
      • Number
      • Boolean
      • Array
      • Buffer
      • Date
      • ObjectId或Oid
      • Mixed
    • 需要为每个不同的文档类型都定义一个模式

创建Model模型对象

  • model(name, [schema], [collection] , [skipInit])

    • name参数相当于模型的名字,以后可以同过name找到模型。

    • schema是创建好的模式对象。

    • collection是要连接的集合名。

    • skipInit是否跳过初始化,默认是false
  • model对象的方法
    • remove(conditions, callback)
    • deleteOne(conditions, callback)
    • deleteMany(conditions, callback)
    • find(conditions, projection, options, callback)
    • findById(id, projection, options, callback)
    • findOne(conditions, projection, options, callback)
    • count(conditions, callback)
    • create(doc, callback)
    • update(conditions, doc, options, callback)
    • ...

创建Document文档对象

  • document对象的方法

    • equals(doc)
    • id
    • get(path,[type])
    • set(path,value,[type])
    • update(update,[options],[callback])
    • save([callback])
    • remove([callback])
    • isNew
    • isInit(path)
    • toJSON()
    • toObject()
    • ...

Mongoose 使用Node操作MongoDB的更多相关文章

  1. Node操作MongoDB并与express结合实现图书管理系统

    Node操作MongoDB数据库 原文链接:http://www.xingxin.me/ Web应用离不开数据库的操作,我们将陆续了解Node操作MongoDB与MySQL这是两个具有代表性的数据库, ...

  2. 使用node操作mongodb

    let mongodb = require('mongodb'); let MongodbClient = mongodb.MongoClient; MongodbClient.connect('mo ...

  3. node操作mongoDB数据库的最基本例子

    连接数据库 var mongo=require("mongodb"); var host="localhost"; var port=mongo.Connect ...

  4. node操作mongodb

    var mongodb = require('mongodb'); var server = new mongodb.Server('localhost', 27017, {auto_reconnec ...

  5. node操作MongoDB数据库之插入

    在上一篇中我们介绍了MongoDB的安装与配置,接下来的我们来看看在node中怎样操作MongoDB数据库. 在操作数据库之前,首先应该像关系型数据库一样建个数据库把... 启动数据库 利用命令提示符 ...

  6. mongoose - 让node.js高效操作mongodb

    Mongoose库简而言之就是在node环境中操作MongoDB数据库的一种便捷的封装,一种对象模型工具,类似ORM,Mongoose将数据库中的数据转换为JavaScript对象以供你在应用中使用. ...

  7. Node使用Mongoose操作MongoDB数据库——增删改查的实现

    当初刚出社会时就规划了下自己的职业生涯:先成为一名优秀的前端工程师,再成为一名全栈工程师(精通前端开发.后台开发和客户端开发),最后成为一名优秀的系统架构师.转眼间已经工作快三年,是时候迈出关键性的一 ...

  8. MONGOOSE – 让NODE.JS高效操作MONGODB(转载)

    Mongoose库简而言之就是在node环境中操作MongoDB数据库的一种便捷的封装,一种对象模型工具,类似ORM,Mongoose将数据库中的数据转换为JavaScript对象以供你在应用中使用. ...

  9. Node.js使用Mongoose包操作MongoDB数据库

    1. 安装Mongoose npm install mongoose 2. 使用 2.1 创建连接 var mongoose = require('mongoose'); mongoose.conne ...

随机推荐

  1. vs2017+opencv配置参考链接

    本人通过以下几篇博客完成vs2017+opencv3.4.1的配置: OpenCV 3.4.1 + VS2017 开发环境搭建 - 简书 WIN10下 VS2017+OpenCv 3.4.1 配置 - ...

  2. highcharts 代码都对,但是不显示图片

    $('#container').highcharts({ chart: { zoomType: 'xy' }, title: { text: 'Average Monthly Temperature ...

  3. 小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_2-7.接口配置文件自动映射到属性和实体类配置

    笔记 7.接口配置文件自动映射到属性和实体类配置     简介:使用@value注解配置文件自动映射到属性和实体类 1.添加 @Component或者Configuration 注解:        ...

  4. 基于request的爬虫练习

    引言 概述 概念:基于网络请求的模块 作用:用来模拟浏览器发请求,从而实现爬虫 通用爬虫 步骤: 指定url 请求发送:get返回的是一个响应对象 获取响应数据: text返回的是字符串形式的响应数据 ...

  5. AP注册

    1.ac发现ap 两种模式:二层发现.三层发现 按ap与ac所处ip网段不同,可以把注册过程分为二层模式和三层模式: 两种模式均通过发送discovery报文进行,二层模式discovery报文仅在同 ...

  6. win系统常用命令

    windows常用命令 net user 用户名 密码 /add (建立用户) net localgroup administrators 用户名 /add (将用户加到管理员,使其拥有管理权限) n ...

  7. Hive概述

    HIVE是什么    开发调试麻烦    只能用java开发     需要对hadoop的底层及api比较了解才能开发复杂代码 HQL Hive是基于Hadoop的一个数据仓库工具.可以将结构化的数据 ...

  8. Opencv 简单视频播放器

    // C++ header and namespace #include <iostream> #include <string> #include <cstdlib&g ...

  9. lua调用shell 脚本

    Lua中,os.execute可以执行dos命令,但是返回的是系统状态码,默认输出.io.popen()也可以执行dos命令,但是返回一个文件.eg: 复制代码 代码如下: local t = io. ...

  10. 【Python】【demo实验22】【练习实例】【猴子吃桃问题】

    原题: 猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个.以后每天早上都吃了前一天剩下的一半零一个.到第10天早上想再吃时,见只 ...