摘要:文档是的核心概念,是键值对的一个有序集,在里文档被表示成对象。创建集合数据库中的集合名称当我们对其添加数据时如果已经存在,则会保存到其目录下,如果未存在,则会创建集合,然后在保存数据。使用创建,如下示例连接成功许巍男保存成功保存失败参考
mongoose简介
mongoose网站:https://mongoosejs.com/
为什么要用MongooseMongoose就是一个让我们可以通过Node来操作MongoDB的一个模块。Mongoose的优势
Mongoose本质是一个对象文档模型(ODM)库,
他对Node原生的MongoDB模块进行了一部优化封装,并且提供了更多的功能。
可以像操作对象一样操作数据库
可以为文档创建一个模式结构(Schema)
可以对模型中的文档/文档进行验证
数据可以通过类型转换为对象模型
可以使用中间件来应用业务逻辑挂钩
比Node原生的MongoDB驱动更容易
使用Mongoose下载安装mongoose模块
cnpm install mongoose --save
引用mongoose:
var mongoose =require("mongoose");
使用"mongoose"连接数据库:
var db =mongoose.connect("mongodb://user:pass@localhost:port/database");
执行下面代码检查默认数据库test,是否可以正常连接成功?
var mongoose =require("mongoose"); var db =mongoose.connect("mongodb://localhost/m_data"); db.connection.on("error",function (error) { console.log("数据库连接失败:" + error); }); db.connection.on("open",function () { console.log("数据库连接成功!"); }); db.connection.once("close", ()=>{ console.log("连接已经断开成功!") })mongoose基本使用 mongoose的几个新的对象
在MongoDB中,多个Document可以组成Collection(以下简称集合),多个集合又可以组成数据库。我们想要操作MongoDB数据,那就得先要具备上面所说的包含数据的“文档”,文档又是什么意思呢,请看如下介绍。
文档 —— 是MongoDB的核心概念,是键值对的一个有序集,在JavaScript里文档被表示成对象。同时它也是MongoDB中数据的基本单元,非常类似于关系型数据库管理系统中的行,但更具表现力。
集合 —— 由一组文档组成,如果将MongoDB中的一个文档比喻成关系型数据库中的一行,那么一个集合就相当于一张表。
Schema—— 一种以文件形式存储的数据库模型骨架,无法直接通往数据库端,也就是说它不具备对数据库的操作能力,仅仅只是定义数据的类型,可以说是数据属性模型(传统意义的表结构),又或着是“集合”的模型骨架。
mongoose中任何任何事物都是从Schema开始的。每一个Schema对应MongoDB中的一个集合(collection)。Schema中定义了集合中文档(document)的样式。
定义一个Schema(表/ 模式对象)//新建Schema 定义规则/字段的规则 let Schema= mongoose.Schema; //定义personSchema的字段(规则)需要new一下 有点像构造函数的样子 let personSchema= new Schema({ name: String, sex: String, age: Number });
基本属性类型有:
String
Number
Date
Boolean
Buffer
ObjectId
Mixed
Array
Model—— 由Schema构造生成的模型,根据Schema定义的数据类型规则,可操作具体的符合改规则的数据。
创建model(集合)let personModel= mongoose.model("person", personSchema);
person:数据库中的集合名称,当我们对其添加数据时如果person已经存在,则会保存到其目录下,如果未存在,则会创建person集合,然后在保存数据。
//4. 插入文档 personModel.create({ name: "张宁乐", sex: "男", age: 18 }, (err)=>{ if(!err){ console.log("插入成功!") }else{ throw err; } });mongoose 插入和查询
mongoose查找数据的一些方法:
https://mongoosejs.com/docs/a...
personModel.create([ {name:"张逗逗",age: 2,sex: "男"}, {name:"牛嘻嘻",age: 2,sex: "女"} ], (err)=>{ if(!err){ console.log("插入成功!") }else{ throw err; } })查询
Model.find()
personModel.find({name: "张宁乐"}, (err, data)=>{ if(!err){ console.log(data) }else{ throw err; } })查询所有
Model.find({}, callback)
personModel.find({}, (err, data)=>{ if(!err){ console.log(data) }else{ throw err; } })
也可以选择查找数据的条件(0隐藏 1显示 id默认显示) 和MongoDB在命令行中的使用方法一样
//查询时只显示name personModel.find({}, {name: 1, _id: 0}, (err,data)=>{ if(!err){ console.log(data) }else{ throw err; } })
在find() 中 skip(查询开始的位置)和limit(增加的条数)也可以使用
personModel.find({}, {name: 1, _id: 0, age: 1}, {skip: 0, limit: 2}, (err, data)=>{ //只显示name 和 age 从第1开始 每次查询2条 if(!err){ console.log(data) }else{ throw err; } })
MongoDB的find()、findOne() 等命令在 mongoose里都可以使用
具体可参考 :https://mongoosejs.com/docs/a...
参考: https://mongoosejs.com/docs/a...
修改方法:Model.update()
Model.updateMany()
Model.updateOne()
Model.watch()
personModel.update({name: "张宁乐"}, {$set: {age: 20}}, (err, data)=>{ if(!err){ console.log("修改成功!") console.log(data) }else{ throw err; } })删除方法
Model.remove()
Model.deleteMany()
Model.deleteOne()
personModel.remove({name:"牛嘻嘻"}, (err)=>{ if(!err){ console.log("删除成功!") }else{ throw err; } })统计文档条数
Model.count()
personModel.count({}, (err,count)=>{ if(!err){ console.log("查询条数成功! 一共:" + count + "条"); }else{ throw err; } })Entity
Entity—— 由Model创建的实体,使用save方法保存数据,Model和Entity的操作都能影响数据库的操作,但Model比Entity更具操作性。
使用Model创建Entity,如下示例:
let mongoose= require("mongoose"); let db= mongoose.connection("mongodb://localhost/m_data"); db.on("open", ()=>{ console.log("连接成功!") }) let Schema= mongoose.Schema; let personSchema= new Schema({ name: String, sex: String, age: Number }); let personModel= mongoose.model("person", personSchema); let personEntity = new personModel({ name: "许巍", sex: "男", age: 38 }) personEntity.save((err, person)=>{ if(!err){ console.log("保存成功!") console.log(person); }else{ console.log("保存失败!") } })
参考:https://blog.csdn.net/swimmin...
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/19435.html
摘要:通过构造而成,除了具有定义的数据库骨架以外,还可以具体的操作数据库。通过创建的实体,它也可以操作数据库。但比更具操作性。 原文链接:Mongoose 前言 学数据库肯定需要知道怎么连接后台Mongoose 是用来方便连接 MongoDB 与 node 的一个工具包是时候学习一波 nodejs连接MongoDB 连接数据库前需要先打开数据库 MongoDB yarn add mongoo...
摘要:项目地址写在开头本文主要分享我如何使用对实现增删改查操作,感谢社区所有精品文章的帮助,以及的开源项目对我的启发。我们这个项目是建立一个班级学生管理系统,能够对学生的姓名及学号进行增删改查的操作。 项目地址:https://github.com/jrainlau/mongoose_cru... 写在开头 本文主要分享我如何使用express+mongoose对mongodb实现增删改查...
最近学习用nodejs做博客系统,用了express框架。数据库采用mongodb,具体用mongoose实现,下面是mongoose的初步了解1、首先要安装mongoose npm install mongoose2、 //db.js const mongoose=require(mongoose);//在文件中引用 const Schema=mongoose.Schema;//schema定义...
最近学习用nodejs做博客系统,用了express框架。数据库采用mongodb,具体用mongoose实现,下面是mongoose的初步了解1、首先要安装mongoose npm install mongoose2、 //db.js const mongoose=require(mongoose);//在文件中引用 const Schema=mongoose.Schema;//schema定义...
阅读 3731·2021-08-11 11:16
阅读 1578·2019-08-30 15:44
阅读 1981·2019-08-29 18:45
阅读 2251·2019-08-26 18:18
阅读 959·2019-08-26 13:37
阅读 1528·2019-08-26 11:43
阅读 2065·2019-08-26 11:34
阅读 336·2019-08-26 10:59