Mongoose基本操作
admin
2024-02-20 05:05:58
0

1、简介

使用Moongoose能够快速操作MongoDB数据库,Moongoose中提供了很多函数,可以使用这些函数MoongoDB数据库进行增加文档、删除文档、查询文档等一些列操作,是Node.js程序

2、使用步骤

1.使用NPM命令下载mongoose到本地

npm i mongoose

2.在app.js文件中编写连接MongoDB数据库服务器的程序

/* 完成mongodb数据库的连接1.导入mongoose模块2.通过mongoose.connect(参数)参数:目标数据库的连接地址,mongodb数据库连接地址的组成协议://ip地址:端口号/数据库名协议:mongodbip地址:如果是本地数据库:127.0.0.1或者localhost端口号:mongodb数据库的默认端口号是27017数据库名:自己创建的数据库3.通过监听数据库的连接情况
*/
const mongoose=require('mongoose')
mongoose.connect("mongodb://127.0.0.1:27017/woniuFoods")
mongoose.connection.on('connected',()=>{console.log('数据库连接成功');})

为了让程序更加清晰,这里我们将如上代码编写在一个独立的文件上,如下所示

首先,在项目的根目录下创建util文件夹,该文件夹以后存放所有的工具函数

其次,在该文件夹下创建database.js,将如上代码复制进入

最后,在app.js文件中引入database.js文件,如下所示

require('./util/database')

3.Schema的配置

在项目根目录下新建model文件夹,该文件夹下存放所有的模型

//引入Schema对象
const {Schema,model}=require('mongoose')
//定义Schema
const swiperSchema=new Schema({_id:Schema.Types.ObjectId,goods_id:Number,image_url:String,navigator_url:String,open_type:String
})

4.定义模型

//定义模型
/* model方法的参数说明参数1:模型的名称参数2:Schema对象参数3:MongoDB数据库中的集合的名称
*/
module.exports.swiperModel=model('swiperModel',swiperSchema,"swipers")

3、CRUD

3.1、查询所有数据

const express=require('express')
const router=express.Router()
const {swiperModel}=require('../model/swiperModel')
//查询所有轮播图图片
router.get('/findAll',async(req,res)=>{//从mongodb数据库woniuFoods/swipers中查询所有的数据let rows=await swiperModel.find()//将数据返回给前端res.send({code:1,rows})
})
module.exports=router

3.2、模糊查询

后端代码实现

router.get('/searchMeals',async(req,res)=>{console.log("*************");let {name}=req.query;//{name:'包年套餐'}let rows=await mealModel.find({name:{$regex:name},state:1})if(rows.length>0){res.send({code:1,message:'查询成功',rows})}else{res.send({code:0,message:'没有查找到相应的套餐信息',rows:[]})}
})

前端代码实现

document.querySelector('#searchBtn').addEventListener('click', async () => {let name = document.querySelector('#name').value;if (name) {let { code, message, rows } = await ajax({type: 'GET',url: '/meal/searchMeals',data: {name: document.querySelector('#name').value}})if (code) {render(rows);} else {document.querySelector("tbody").innerHTML = `${message}`}} else {render(rows)}})

3.3、删除操作

前端代码实现

第1步:在列表渲染方法中设置删除按钮

第2步:为按钮绑定单击事件,并完成向后端发送请求

document.querySelector("tbody").addEventListener('click', async e => {if (e.target.className == "delBtn") {if (window.confirm('您确定要删除吗?')) {let _id = e.target.parentElement.getAttribute("ids");let { code, message, rows } = await ajax({ type: 'DELETE', url: '/meal/delMeal',data: { _id } })if (code) {window.alert(message)render(rows);} else {window.alert(message);}}}})

后端代码实现

router.delete('/delMeal',async(req,res)=>{let {deletedCount}=await mealModel.deleteOne(req.body)let rows=await mealModel.find();deletedCount?res.send({code:1,message:'套餐删除成功',rows}):res.send({code:0,message:'套餐删除失败',rows:[]})
})

3.4、按ID查询

后端操作

router.get('/getMealById',async(req,res)=>{console.log(req.query);try{let data=await mealModel.findById(req.query)res.send({code:1,message:'查询成功',data})}catch(err){res.send({code:0,message:'查询失败'})}
})

说明

  • 按ID查询的方法有两种

    • 通过mealModel.find()
    • 通过mealModel.findById()

    这两种查询方式不同点,第一种方式查询后的结果是一个数组,然后对象放在数组中;第二种方式查询的结果就是一个对象

  • 通过ID查询和别的查询不同点,如果ID不对就报异常了,所以处理过程中要通过异常处理的方式来解决

前端操作

  • 首先给详情按钮设置class,主要为了后续事件委托的时候能找到

  • 通过事件委托的方式为查看按钮绑定单击事件,绑定后在事件回调函数中跳转到详情页
    document.querySelector("tbody").addEventListener('click',async e=>{if (e.target.className == "detailBtn") {let _id = e.target.parentElement.getAttribute("ids");window.location.href=`../detail.html?id=${_id}`}})

  • 在详情页页面加载的时候,获取到上一页传递的ID,并且向服务端发送请求来获取数据
    window.addEventListener('DOMContentLoaded',async()=>{let _id=location.search.split("=")[1];let {code,message,data:{_id:id,mouth,name,normalPrice,salePrice}}=await      ajax({type:'GET',url:'/meal/getMealById',data:{_id}})document.querySelector("#name").innerHTML=name;document.querySelector("#mouth").innerHTML=mouth;document.querySelector("#normalPrice").innerHTML=normalPrice;document.querySelector("#salePrice").innerHTML=salePrice;
    })

    3.5、修改操作

    后端实现

    router.post('/updateMeal',async(req,res)=>{let {modifiedCount}=await mealModel.updateOne({_id:req.body._id},req.body)modifiedCount?res.send({code:1,message:'修改成功'}):res.send({code:0,message:'修改失败'})
    })

    前端实现

  • 首先给修改按钮设置class,主要为了后续事件委托的时候能找到

  • 通过事件委托的方式为修改按钮绑定单击事件,绑定后在事件回调函数中跳转到修改页
    document.querySelector("tbody").addEventListener('click',async e=>{if (e.target.className == "updateBtn") {let _id = e.target.parentElement.getAttribute("ids");window.location.href=`../update.html?id=${_id}`}
    })

  • 修改页具体js实现
    window.addEventListener('DOMContentLoaded',async()=>{let _id=location.search.split("=")[1];let {code,message,data:{_id:id,mouth,name,normalPrice,salePrice}}=await    ajax({type:'GET',url:'/meal/getMealById',data:{_id}})document.querySelector("#name").value=name;document.querySelector("#mouth").value=mouth;document.querySelector("#normalPrice").value=normalPrice;document.querySelector("#salePrice").value=salePrice;document.querySelector("#id").value=_id;document.querySelector("#updateBtn").addEventListener('click',async()=>{let _id=document.querySelector("#id").value; let name=document.querySelector("#name").value;let mouth=document.querySelector("#mouth").valuelet normalPrice=document.querySelector("#normalPrice").valuelet salePrice=document.querySelector("#salePrice").valuelet {code,message}=await ajax({type:'POST',url:'/meal/updateMeal',data:{_id,name,mouth,normalPrice,salePrice}})alert(message);})
    })

    3.6、增加操作

    1.模型设置

    const {Schema,model}=require('mongoose')
    //定义Schema
    const mealSchema=new Schema({mouth:Number,name:String,normalPrice:Number,salePrice:Number,state:Number,type:Number
    },{versionKey:false
    })
    //定义模型
    module.exports.mealModel=model("mealModel",mealSchema,"meal")

    备注:如果要让mongdb自动产生ID为24位的ObectId格式,就不要在模型上设置_id

    如果自己要在前台输入字符串为编号,可以如下设置模型

    const {Schema,model}=require('mongoose')
    //定义Schema
    const mealSchema=new Schema({_id:String,mouth:Number,name:String,normalPrice:Number,salePrice:Number,state:Number,type:Number
    },{versionKey:false
    })
    //定义模型
    module.exports.mealModel=model("mealModel",mealSchema,"meal")

    2.后端代码编写

    router.post('/addMeal',async(req,res)=>{//获取请求参数let meal=req.body//通过后端设置的meal.type=0meal.state=1//添加数据到数据库集合中  try{await mealModel.create(meal)res.send({code:1,message:'套餐增加成功'})}catch(err){res.send({code:0,message:'套餐增加失败'})}    
    })

    3.前端代码实现

    window.addEventListener('DOMContentLoaded',()=>{document.querySelector('#addBtn').addEventListener('click',async()=>{let {code,message}=await ajax({type:'POST',url:'/meal/addMeal',data:{_id:document.querySelector("#no").value,name:document.querySelector("#name").value,mouth:document.querySelector('#mouth').value,normalPrice:document.querySelector('#normalPrice').value,salePrice:document.querySelector('#salePrice').value,}})if(code){alert(message);window.location.href="meal.html";}else{alert(message)}})
    })

相关内容

热门资讯

安卓系统最强定位手机版,最强定... 你有没有想过,在茫茫人海中,如何让你的手机定位功能像侦探一样精准无误?今天,就让我带你一探究竟,揭秘...
安卓运行环境选哪个系统,And... 你有没有想过,你的安卓手机到底是在哪个运行环境下才能发挥出最佳性能呢?这可是个技术活儿,选对了系统,...
zui15系统是安卓系统吗,揭... 亲爱的读者,你是否曾好奇过,那些在手机上运行得风生水起的系统,它们究竟是不是安卓的呢?今天,就让我带...
ios系统和安卓系统权限区别,... 你有没有发现,无论是手机还是平板,我们用的最多的就是那些APP了。而这些APP,它们在手机里可是有着...
荣耀手环6安卓版系统,智能生活... 你有没有注意到,最近你的手腕上是不是多了一抹亮丽的色彩?没错,说的就是荣耀手环6安卓版系统!这款智能...
极品奴隶系统下载安卓版,体验独... 你有没有听说过那个超级火的“极品奴隶系统”安卓版?最近,这款游戏在朋友圈里可是炸开了锅,大家都说它好...
安卓手机苹果系统扣费,揭秘扣费... 你有没有遇到过这种情况?手机里突然多了一笔扣费,而且还是那种你完全没意识到的扣费?尤其是当你用的是安...
安卓系统智能电视刷机,焕新体验 亲爱的电视迷们,你是否曾为你的安卓智能电视的性能所困扰?是不是觉得它运行缓慢,功能受限?别担心,今天...
安卓系统无法安装applica... 最近是不是遇到了安卓系统无法安装application的烦恼?别急,让我来帮你一探究竟,解决这个让人...
怎么取消安卓系统锁屏,解锁锁屏... 手机锁屏功能虽然能保护我们的隐私,但有时候也会让人头疼,比如忘记密码或者想快速查看信息时。那么,怎么...
安卓系统高德怎么下载,轻松获取... 你有没有发现,现在手机上导航软件真是越来越方便了?尤其是安卓系统的用户,高德地图这款神器简直成了出行...
安卓系统的开源部分,开源代码背... 你知道吗?安卓系统,这个在我们手机上无处不在的小家伙,竟然有一部分是开源的!是不是觉得有点神奇?别急...
小米下载安卓13系统,畅享智能... 亲爱的手机控们,你是否已经迫不及待想要体验最新的操作系统呢?没错,我说的就是安卓13系统!而今天,我...
安卓系统如何设置拍月亮,捕捉夜... 月亮,那轮皎洁的夜空明珠,总是让人心生向往。你是否也想用你的安卓手机捕捉到它的美丽瞬间呢?别急,今天...
安卓v8以上系统,探索安卓V8... 你知道吗?最近手机界可是掀起了一股新潮流,那就是安卓V8以上系统。这可不是什么小打小闹,而是实实在在...
安卓系统兼容哪个版本好,哪个版... 你有没有想过,你的安卓手机到底兼容哪个版本的系统最好呢?这可是个技术活儿,得好好研究研究。别急,今天...
安卓平板安装linux桌面系统... 你有没有想过给你的安卓平板来个变身大法?没错,就是给它安装一个Linux桌面系统!想象原本只能刷刷剧...
安卓什么手机系统bug最少,揭... 你有没有发现,用安卓手机的时候,有时候会遇到一些小麻烦,比如系统突然卡顿,或者某个应用突然崩溃,真是...
手机软件安卓下载系统,解锁手机... 你有没有发现,现在的生活越来越离不开手机了?手机里装满了各种各样的软件,让我们的生活变得更加便捷。今...
微软系统和安卓系统的cad软件... 你有没有想过,为什么你的电脑里装的是微软系统,而朋友的手机上却是安卓系统?这背后其实隐藏着一场关于操...