Node.js -- mongoose

文章目录

  • 1. 介绍
  • 2. mongoose 连接数据库
  • 3. 插入文件
  • 4. 字段类型
  • 5. 字段值验证
  • 6. 文档处理
    • 6.1 删除文档
    • 6.2 更新文档
    • 6.3 读取文档
  • 7. 条件控制
  • 8. 个性化读取
  • 9. 代码模块化

1. 介绍

Mongoose是一个对象文档模型库,官网http://www.mongoosejs.net/
方便使用代码操作mongodb数据库
mangoose 本身是一个包

在这里插入图片描述
上节内容Node.js – MongoDB
我们学习了在命令行手动交互,发命令请求,项目运行阶段明显是不可行的,但是我们可以借助mongoose

2. mongoose 连接数据库

  1. 创建一个文件夹,对其npm i -y 初始化
  2. 安装npm i mongoose
  3. 创建测试文件
  4. 导入mongoose

const mongoose = require(‘mongoose’)

  1. 连接 mongodb 服务

mongoose.connect(‘服务url’)
mongoose.connect(‘mongodb://127.0.0.1/test’)
其中端口号:27017 可写可不写 因为mongodb 的默认端口就是:27017 test 指的是数据库名称

  1. 设置回调

// 设置连接成功的回调
mongoose.connection.on(‘open’,()=>{
console.log(‘连接成功’)
})

// 设置连接失败的回调
mongoose.connection.on(‘error’,()=>{
console.log(‘连接失败’)
})

// 设置连接关闭的回调
mongoose.connection.on(‘close’,()=>{
console.log(‘连接关闭’)
})
// 关闭mongodb 的连接
setTimeOut(()=>{
mongoose.disconnect()
},2000)

补充说明
在这里插入图片描述

  1. 我们运行测试文件后可能会出现上图所示的警告,如果需要规避这个警告可以在文件中添加:

mongoose.set(‘strictQuery’,true)

  1. 设置连接成功的回调 once 只执行一次
mongodb.connection.once('open',()=>{
console.log('连接成功')
})

连接服务成功会执行回调函数,但是mongodb 服务如果意外掉线,on()会重新连接服务,once() 不会再连接服务;但是官方更推荐使用once() ,因为’open’ 事件中会写一些功能代码,重连服务会出现端口被占用的情况,导致某些代码无法运行。

这部分补充内容了解即可。

3. 插入文件

const mongoose = require('mongoose')mongoose.connect('mongodb://127.0.0.1:27017/test')mongoose.connection.on('open', () => {// 1. 创建文档的结构对象// 设计集合中文档的属性以及属性值的类型let UserSchema = new mongoose.Schema({name: String,birthYear: Number,order:Number})// 2. 创建模型对象 对文档操作的封装对象// 对文档的操作需要通过UserModel 进行let UserModel = mongoose.model('users', UserSchema)// 3. 新增UserModel.create({name: '王一珩',birthYear: 2004,order:10}, (err, data) => {if (err) {console.log(err);} // 没有出错就输出插入后的文档对象console.log(data);// 关闭连接 但是项目运行阶段一般都不会关闭mongoose.disconnect()})})mongoose.connection.on('error', () => {console.log('连接失败');
})mongoose.connection.on('close', () => {console.log('连接关闭');
})
// 设置服务在2s 后关闭
setTimeout(() => {mongoose.disconnect()
}, 2000)

4. 字段类型

文档结构可选的常用字段类型列表
字段类型也可以说是指文档对象的属性值类型

类型描述
String字符串
Number数字
Boolean布尔值
Array数组,也可以使用[ ]来标识
Date日期
BufferBuffer对象
Mixed任意类型,需要使用mongoose.Schema.Types.Mixed 指定
Objected对象ID,需要使用mongoose.Schema.Types.Objected
Decimal128高精度数字,需要使用mongoose.Schema.Types.Decimal128

存储视频、图片一般都是存储在静态资源文件夹下,把相应的url 以字符串的形式存储在数据库中,使用的时候就按照url 到数据库中寻找;

Objected :一般用来做外键,就是将一个文档的ID存储到另一个文档中,当需要这个文档的数据是就通过ID 进行数据查询;

5. 字段值验证

mongoose 有一些内建验证器,可以对字段值进行验证

  1. 必填项

title:{
type:String,
required:true}

  1. 默认值

author:{
type: String,
default: ‘匿名’
} // 设置文档对象没有传入author值,那author 值默认就为 匿名

  1. 枚举值

gender:{
type:String,
enum:[‘男’,‘女’]
} // 设置的值必须是数组中的

  1. 唯一值

username:{
type:String,
unique: true
}
unique 需要重建集合才有效,也就是创建新的集合

6. 文档处理

6.1 删除文档

  1. 删除单条数据
// 创建模型对象对文档操作的封装对象 mongoose会使用集合名称的复数,创建集合
let BookModel = mongoose.model('novel',BookSchema);
// 集合名称就为novels
// 删除一条
BookModel.deleteOne({_id:'63f34af50cf203761ede1892'},(err,data)=>{
//判断
if(err){
console.log('删除失败')return;
}
//输出data
console.log(data);
  1. 批量删除
BookModel.deleteMany({is_hot:false},(err,data)=>{
//判断
if(err){
console.1og('删除失败')return;
}
//输出data
console.log(data);
})

6.2 更新文档

  1. 更新一条
BookModel.updateOne({name:'红楼梦'},{price:9.9},(err,data)=>{
//判断 err
if (err) {
console.log('更新失败')
return
}
// 输出data
console.log(data);
  1. 批量更新
//批量更新
BookModel.updateMany({author:''},{is_hot:true},(err,data)=>{
//判断
if(err){
console.log('更新失败');
return;
}
//输出data
console.log(data);
})

6.3 读取文档

  1. 读取一条
BookModel.findOne({name:'红楼梦'},(err,data)=>{
//判断 err
if (err) {
console.log('读取失败')
return
}
// 输出data
console.log(data);// 也可以使用根据ID 获取数据  findById()
BookModel.findById({id:'12345678790'},(err,data)=>{
//判断 err
if (err) {
console.log('读取失败')
return
}
// 输出data
console.log(data);
  1. 批量读取
BookModel.find({author:''},(err,data)=>{
//判断
if(err){
console.log('读取失败');
return;
}
//输出data
console.log(data);
  1. 读取所有
BookModel.find((err,data)=>{
//判断
if(err){
console.log('读取失败');
return;
}
//输出data
console.log(data);
})

7. 条件控制

  1. 运算符
    本节内容的代码中我们都是通过 ‘=’ 进行检索内容,但是其他的运算符也可以进行检索内容。

在mongodb不能><>=<=!=等运算符,需要使用替代符号

  • ‘>’ 使用$ gt
  • ‘<’ 使用$ lt
  • ‘>=’ 使用$ gte
  • ‘<=’ 使用$ lte
  • ‘!==’ 使用$ ne

db.students.find({id: {$ gt: 3}) id号比3大的所有记录

let BookModel = mongoose.model('novel',BookSchema);
// 价格<20的图书
BookModel.find({price:{$lt:20}},(err,data)=>{
if(err)
console.log('读取失败')return;
console.log(data);
})
  1. 逻辑运算

$or 逻辑或的情况

db.students.find({$or [{age:18},{age:24}]))

$and 逻辑与的情况

db.students.find({$ and: [{age:{$ lt:20}},{age: {$gt:15}}]});

  1. 正则匹配
    条件中可以直接使用JS的正则语法,通过正则可以进行模糊查询

db.students.find({name: /imissyou/ }) // 找出name 中含有imissyou 的文档对象

8. 个性化读取

  1. 字段筛选
// 0:不要的字段
// 1:要的字段
SongModel.find().select({_id:0,title:1}).exec(function(err,data)=>{
if(err){
console.log(err)
}
console.log('data')
mongoose.connection.close()
})

在这里插入图片描述

  1. 数据排序
// sort 排序
// 1:升序
// -1:倒序
SongModel.find().select({_id:0,price:1}).sort({price:-1}).exec(function(err,data)=>{
if(err){
console.log(err)
}
console.log('data')
mongoose.connection.close()
})
  1. 数据截取
// 取前三个
SongModel.find().select({_id:0,price:1}).sort({price:-1}).limit(3).exec(function(err,data)=>{
if(err){
console.log(err)
}
console.log('data')
mongoose.connection.close()
})// 取第4-6位
SongModel.find()
.select({_id:0,price:1})
.sort({price:-1})
.skip(3)
.limit(3)
.exec(function(err,data)=>{
if(err){
console.log(err)
}
console.log('data')
mongoose.connection.close()
})

9. 代码模块化

  • 创建连接部分
  1. 新建文件夹db 接着新建文件db ,再其中把创建连接代码部分放入暴露的函数中
    在这里插入图片描述
    注意:
    连接成功泽调用success 函数,连接失败调用error函数

  2. 导入函数,调用函数,传入success、error函数
    在这里插入图片描述

  • 创建结构对象和模型对象部分
  1. 创建modules 文件夹 再创建BookModel.js ,放入重复创建的代码部分;
    在这里插入图片描述

  2. 只需要在文件中导入两部分模板内容,传入函数的success和error 参数

在这里插入图片描述

  • 模板化调用函数的error参数部分
  1. 不再传入error参数
  2. 判断error 是否为函数
    在这里插入图片描述
  • 配置文件

连接的url、端口号、集合都有可能发生改变,所以我们可以把其中内容写入到配置文件中,将来再修改的时候也更加方便;

  1. 创建config 文件夹 ,在创建config 文件,放入url、端口号、集合等内容
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/831300.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

next.js v14 从入门到跑路

用next.js也有几天了&#xff0c;也是这么一个边看边用这么一个状态&#xff0c;现在主要使用app router模式&#xff0c;更新下next.js v14 app router模式方面的姿势吧。 区别于前面的pages router, app router虽然也是根据目录结构来划分路由&#xff0c;但是它不再依赖于使…

【Godot4.2】EasyTreeData通用解析

概述 之前在《【Godot4.2】Tree控件自定义树形数据ETD及其解析》一文中&#xff0c;实现了对带缩进的层级结构文本的解析&#xff0c;并将其用于Tree控件的列表项构造。 不过当时并没有实现专门的类&#xff0c;今天花了一点时间实现了一下。现在可以更方便的构造和解析ETD数…

数据库面试常问

数据定义语言&#xff08;DDL&#xff09;&#xff1a; CREATE TABLE&#xff1a;用于创建数据库表格。例如&#xff1a;CREATE TABLE students (id INT, name VARCHAR(50), age INT);DROP TABLE&#xff1a;用于删除数据库表格。例如&#xff1a;DROP TABLE students;CREATE I…

“Unite“ > MacOS下很不错的网站转应用App的工具

前言 前不久在浏览mac论坛&#xff0c;无意了解到一款非常好的工具&#xff0c;可以将网站转换为app&#xff0c;考虑到我们现在的主要应用都从本地客户端转成web形式使用&#xff0c;但基于本能的使用习惯&#xff0c;还是希望有个快捷的访问信息&#xff0c;这个应用非常适合…

数组删除元素

数组删除元素 1.利用新的数组 将原数组arr的元素&#xff0c;复制到新数组newArr中&#xff0c;复制过程中将要删除的元素&#xff0c;选择不复制 public class Test01{public static void main(String [] args){String [] arr {"zhangsan","lisi","…

C语言——操作符保姆级教学(含整形提升及算数转换)

操作符 一.操作符的分类二.原码、反码、补码三.移位操作符1.左移操作符&#xff1a;<<2.右移操作符&#xff1a;>> 四.位操作符1.按位与—— &2.按位或—— |3.按位异或—— ^4.按位取反—— ~ 五.逗号表达式六.条件操作符七.操作符的属性&#xff1a;优先级、…

408数据结构-树的基本概念与性质 自学知识点整理

树的定义 树是 n n n&#xff08; n ≥ 0 n≥0 n≥0&#xff09;个结点的有限集。当 n 0 n0 n0时&#xff0c;称为空树。 任意一棵非空树应具有以下特性&#xff1a; 有且仅有一个特定的被称为根的结点&#xff08;根结点&#xff09;。当 n &#xff1e; 1 n&#xff1e;1 …

PotatoPie 4.0 实验教程(32) —— FPGA实现摄像头图像浮雕效果

什么是浮雕效果&#xff1f; 浮雕效果是一种图像处理技术&#xff0c;用于将图像转换为看起来像浮雕一样的效果&#xff0c;给人一种凸起或凹陷的立体感觉&#xff0c;下面第二张图就是图像处理实现浮雕效果。 不过这个图是用Adobe公司的PS人工P图实现的&#xff0c;效果比较…

第一课 自动驾驶概述

1. contents 2. 什么是无人驾驶/自动驾驶 3 智慧出行大智慧 4. 无人驾驶的发展历程

Tracecat:开源 SOAR

Tracecat 是一个面向安全团队的开源自动化平台。 开发人员认为&#xff0c;每个人都应该可以使用安全自动化&#xff0c;特别是人手不足的中小型团队。 核心功能、用户界面和日常工作流程基于一流安全团队的现有最佳实践。 使用专门的人工智能模型来标记、总结和丰富警报。 …

Vagrant CentOS7 安装 Docker 及使用 Docker 安装 MySQL

1、安装 Docker 1.1、删除旧版本 sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine 1.2、安装必要的依赖包 sudo yum install -y yum-utils 1.3、配置源地址&#xf…

Spark RDD的分区与依赖关系

Spark RDD的分区与依赖关系 RDD分区 RDD&#xff0c;Resiliennt Distributed Datasets&#xff0c;弹性式分布式数据集&#xff0c;是由若干个分区构成的&#xff0c;那么这每一个分区中的数据又是如何产生的呢&#xff1f;这就是RDD分区策略所要解决的问题&#xff0c;下面我…

<Linux> 权限

目录 权限人员相对于文件来说的分类更改权限文件的拥有者与所属组 权限 权限是操作系统用来限制对资源访问的机制&#xff0c;权限一般分为读、写、执行。系统中的每个文件都拥有特定的权限、所属用户及所属组&#xff0c;通过这样的机制来限制哪些用户、哪些组可以对特定文件…

VULHUB复现log4j反序列化漏洞-CVE-2021-44228

本地下载vulhub复现就完了&#xff0c;环境搭建不讲&#xff0c;网上其他文章很好。 访问该环境&#xff1a; POC 构造&#xff08;任选其一&#xff09;&#xff1a; ${jndi:ldap://${sys:java.version}.xxx.dnslog.cn} ${jndi:rmi://${sys:java.version}.xxx.dnslog.cn}我是…

Redis 实现分布式Session 登录相关细节

Redis 实现分布式Session 登录 借助 Redis 对 Session 信息进行统一的存储和管理&#xff0c;这样无论请求发送到哪台服务器&#xff0c;服务器都会去同一个 Redis 获取相关的 Session 信息&#xff0c;这样就解决了分布式系统下 Session 存储的问题。 【发送短信】校验手机号…

centos 中使用 kubekey 安装 k8s v1.22.12 支持 GPU 调用

环境准备&#xff1a; https://blog.csdn.net/m0_64519023/article/details/138184970 生成配置文件&#xff1a; 中间需要执行 ./kk create config --with-kubernetes v1.22.12 这个命令生成配置文件&#xff0c;保留生成的配置文件中 spec: hosts 下的 node1&#xff0c;将…

NLP自然语言处理和应用场景介绍

【A】NLP&#xff08;Natural Language Processing&#xff0c;自然语言处理&#xff09;是计算机科学与人工智能领域的一个分支&#xff0c;旨在让机器能够理解、解释、生成人类语言。它涵盖了语言文本的语法、语义、语用、语境等方面的处理。 NLP的具体应用场景包括但不限于…

双向链表专题

文章目录 目录1. 双向链表的结构2. 双向链表的实现3. 顺序表和双向链表的优缺点分析 目录 双向链表的结构双向链表的实现顺序表和双向链表的优缺点分析 1. 双向链表的结构 注意&#xff1a; 这⾥的“带头”跟前面我们说的“头节点”是两个概念&#xff0c;带头链表里的头节点…

C#描述-计算机视觉OpenCV(3):重映射

C#描述-计算机视觉OpenCV&#xff08;3&#xff09;&#xff1a;重映射 前言色彩波形图像重映射 前言 C#描述-计算机视觉OpenCV&#xff08;1&#xff09;&#xff1a;基础操作 C#描述-计算机视觉OpenCV&#xff08;2&#xff09;&#xff1a;图像处理 在前文中&#xff0c;描…

读取文件例题总结 python

主要是读取文件的操作&#xff0c;结合字典&#xff0c;列表&#xff0c;集合的综合例题 主要思路&#xff1a;先看文件结构 根据文件结构 划分 然后保存到列表中&#xff08;一般是二维列表&#xff09; 然后再保存到字典中进行一些列操作 1…学生成绩分析 #1.学生成绩分析…