NodeJs Express框架操作MongoDB数据库执行方法讲解
1、Mongoose模块
(1)是一个对象模型工具,是对Node.js环境下操作MongoDB数据库进行了封装,可以将MongoDB数据库中的数据转换成JavaScript对象供用户使用。
(2)名词:
- Schema:它是一种以文件形式存储的数据库模型骨架,不具备对数据库操作的能力,仅仅只是数据库在程序片段中的一种表现,可以理解为表结构。
- Model:由Schema发布生成的模型,具有抽象属性和行为的数据库操作
- Entity:由Model创建的实体,它的操作也会影响数据库
(3)命名规范:驼峰命名 例:
PersonSchema:Person对应的Schema ,Person的文本属性(表结构)
PersonModel:Person对应的Model
PersonEntity:Person对应的Entity
Schema生成Model,由Model生成Entity,Model和Entity都可以操作数据库,Model的可操作性更强。
2、Mongoose模块的使用
(1)安装:npm install mongoose
(2)创建数据库连接文件
// 导入mongoose模块 const Mongoose = require('mongoose'); // 定义MongoDB数据库的连接字符串:协议://主机地址:端口号/数据库名 const mdb_url = 'mongodb://localhost:27017/my_test'; /* 建立和MongoDB数据库的连接 useNewUrlParser:是否使用新的url地址转换方式 useUnifiedTopology:是否使用新的用户安全策略 */ Mongoose.connect(mdb_url,{useNewUrlParser:true,useUnifiedTopology:true}); // 对连接过程进行处理 // 建立连接 ——连接成功触发connected事件 Mongoose.connection.on('connected',()=>{ console.log('数据库连接成功~'+mdb_url); }) // 连接异常 ——回调函数的参数中保存了异常的信息 Mongoose.connection.on('error',(e)=>{ console.log(e); }) //断开连接 ——断开连接触发 Mongoose.connection.on('disconnected',()=>{ console.log('断开数据库的连接~'); }) // 导出mongoose module.exports = Mongoose;
(3)创建Schema,再由Schema创建Model
- Schema:定义的是与集合对应的骨架。Schema中的属性对应的是MongoDB中集合的key。
- 是Schema的实例,用于操作MongoDB中的集合中的文档。
3、关于模型名称和数据库中集合名称的对应关系
(1)数据库中没有集合
mongoose.model('Admin',AdminSchema) ——>在模型名后加s就是集合名(不区分大小写) ——admins
mongoose.model('Admin',AdminSchema,'admin')——>第三个参数就是用于定义的集合名称
(2)数据库中有集合
mongoose.model('Admin',AdminSchema,'数据库中已有的集合名')
4、mongoose的基本操作
(1)插入文档:save方法
- 先使用Model创建Entity
- 然后使用Entity调用save方法
const AdminModel = require('../model/adminModel'); // 通过model创建一个对象 const admin = new AdminModel({ _id:'1005', userName:'唐僧', password:'123456', address:'东土大唐' }) /* * 通过对象调用save方法向数据库中插入数据err存放的是保存失败后的信息 res是保存的对象 */ admin.save((err,res)=>{ if(err){ console.log(err); }else{ console.log(res); } })
(2)删除文档:findByIdAndDelete :直接通过Model调用,作用是根据文档的_id属性删除
(3)删除文档:deleteOne:直接通过Model调用,根据给定的条件删除文档
(4)更新文档:findOneAndUpdate,直接通过Model调用
findOneAndUpdate(条件,更新语句,{},回调函数)
AdminModel.findOneAndUpdate( {'_id':'1004'}, //表示查询的条件 {$set:{'password':'789567'}}, //更新语句 null, //表示查询操作,通常为null (err,data)=>{ //更新回调函数,err表示数据库的错误信息,data中存放的findOne查询到的文档 if(err){ console.log(err); //err表示数据库错误:查询、更新时数据库出现异常 }else if(!data){ //data为null时表示没有找到对应的文档 console.log('更新失败~'); }else if(data){ //data不为null时表示找到对应的文档 console.log('更新成功~') } })
(5)更新文档:updateOne(条件,更新语句,回调函数)
AdminModel.updateOne({'password':'123456'},{$set:{'password':'567890'}},(err,data)=>{ if(err){ console.log(err); } console.log(data.modifiedCount); })
(6)查询所有:find
AdminModel.find((err,data)=>{ if(err){ console.log(err); } console.log(data); })
(7)按_id查询:findById
AdminModel.findById({ '_id':'1004' },(err,data)=>{ if(err){ console.log(err); } console.log(data); })
(8)多条件查询:findOne 返回满足条件的第一条记录
AdminModel.findOne({ address:'三国', password:'123456' },(err,data)=>{ if(err){ console.log(err); } console.log(data) })
(9)查询集合中的文档数量 :count
AdminModel.count((err,data)=>{ if(err){ console.log(err); } console.log('记录数:'+data); })
到此这篇关于NodeJs Express框架操作MongoDB数据库执行方法讲解的文章就介绍到这了,更多相关NodeJs操作MongoDB数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
- node.js+express+mySQL+ejs+bootstrop实现网站登录注册功能
- node.js平台下利用cookie实现记住密码登陆(Express+Ejs+Mysql)
- 零基础搭建Node.js、Express、Ejs、Mongodb服务器及应用开发入门
- express框架通过ejs模板渲染输出页面实例分析
- Express 框架中使用 EJS 模板引擎并结合 silly-datetime 库进行日期格式化的实现方法
- nodejs中的express-jwt的使用解读
- NodeJS Express使用ORM模型访问关系型数据库流程详解
- NodeJs Express路由使用流程解析
- NodeJs Express中间件使用流程解析
- express框架+bootstrap美化ejs模板实例分析
相关文章
[将免费进行到底]在Amazon的一年免费服务器上安装Node.JS, NPM和OurJS博客
此文是介绍如何在Amazon的一年免费计划上安装Node.JS, NPM还有搭建OurJS博客系统。,需要的朋友可以参考下2014-08-08nodejs操作mongodb的填删改查模块的制作及引入实例
下面小编就为大家分享一篇nodejs操作mongodb的填删改查模块的制作及引入实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-01-01node实现shell命令管理工具及commander.js学习
这篇文章主要为大家介绍了node实现shell命令管理工具及commander.js学习,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-09-09
最新评论