使用 node.js 和 MongoDB 编写一个简单的增删改接口 demo

文章目录

前言


Mongoose 是一个在 Node.js 环境中操作 MongoDB 数据库的工具库。它提供了一种在 Node.js 中进行数据库操作的简单、直观、异步的方式,可以用来定义数据模型、执行查询、更新和删除操作,以及进行数据验证等功能。通过 Mongoose,开发者可以更方便地操作 MongoDB 数据库,提高开发效率。

一、环境准备

确保已安装:

  • Node.js (≥ 14.x)
  • MongoDB (≥ 4.x)

初始化项目并安装依赖:

js 复制代码
mkdir node-mongo-demo
cd node-mongo-demo
npm init -y
npm install express mongoose dotenv

二、项目结构

node-mongo-demo/

js 复制代码
├── .env
├── db/
│   └── connect.js
├── models/
│   └── BannerModel.js
├── routes/
│   └── server.js
├── app.js
└── package.json

三、环境变量

创建 .env 文件(用于环境变量):

js 复制代码
MONGODB_URI= mongodb://localhost:1818/demo
PORT=3000

四、连接数据库

在 db/connect.js 中连接 MongoDB 数据库:

3.1. connect.js 文件

js 复制代码
const express = require('express');
const mongoose = require('mongoose');
require('dotenv').config();

const app = express();
app.use(express.json()); // 解析 JSON 请求体

// 连接 MongoDB
mongoose.connect(process.env.MONGODB_URI)
  .then(() => console.log('MongoDB 已连接'))
  .catch(err => console.error('MongoDB 连接错误:', err));

// 路由
app.use('/items', require('./routes/items'));

// 启动服务器
app.listen(process.env.PORT, () => {
  console.log(`服务端口: ${process.env.PORT}`);
});

五、定义数据模型

在 models/BannerModel.js 中定义数据模型:

定义了一个名为 BannerSchema 的模式(Schema),它包含了五个字段:imgPath、url 、 name 、 description 和 price。字段被定义为 字符串 和 数值 类型,可以设置 必填 的(required: true)。可以设置默认值 (default: '')。可以设置数值最小值 (min: 0)。

然后,您使用这个模式创建了一个 Mongoose 模型(model),命名为 Banner。这个模型可以用来创建、查询、更新和删除 MongoDB 中的 Banner 集合(Collection)。

最后,您将这个模型赋值给了 module.exports,这样其他文件就可以通过 require 引用这个模型,并使用它与 MongoDB 交互。

5.1. BannerModel.js 文件

js 复制代码
const mongoose = require('mongoose');
const Schema = mongoose.Schema;

let BannerSchema = new Schema({
  imgPath: { type: String, required: true },
  url: { type: String, required: true },
  name: { type: String, required: true },
  description: { type: String, default: '' },
  price: { type: Number, min: 0 }
});

let model = mongoose.model('Banner', BannerSchema);
module.exports = model;

六、实现 server 接口

6.1. server.js 文件

js 复制代码
const express= require('express');
const router= require('router');
const Banner= require('../db/BannerModel.js');

// 获取 banner 数据
router.get('./getBanner',( req,res)=>{
     console.log('getBanner')
     Banner.find().then((data)=>{
          res.send({err:0,msg:'查询ok',data:data})
     }).catch((err)=>{
          res.send({err:-1,msg:'查询不成功'})
     }) 
})

// 删除 banner
router.post('./delBanner',( req, res )=>{
     console.log('gdelBanner')
})

// 新增 banner 数据
router.post('./addBanner',( req, res)=>{
	console.log(req.body)
    let {imgPath,url,name}= req.body
    Banner.insertMany({imgPath,url,name}).then((data)=>{
         res.send({ err:0,msg:'添加成功' })
    }).catch((err)=>{
         res.send({ err:-1,msg:'添加失败' })
    })     
})

// 修改 banner 数据
router.post('./updateBanner',( req, res)=>{
     Banner.update( {_id:id}, {imgPath,url,name} )
     console.log('getBanner')
})

module.exports = router;

七、服务文件

在 app.js 中连接 MongoDB:

7.1. app.js 文件

js 复制代码
const express= require('express');
const path= require('path');
const app= express()
const db= require('./src/db/connect.js')
//post配置
var bodyParser= require('body-parser')
app.use(bodyParser.json())
app.use(bodyParser.urlencoded({ extended:false }))

//配置静态目录
app.use(express.static( path.json( __diename,'./atatic' )))
//路由相关
const server= require('./src/routes/server.js')
app.use('./server', server)

app.listen(3000,()=> {
    console.log('服务器启动')
})

八、感谢

如果觉得有用欢迎点赞关注收藏。

有问题私信我!!~~

相关推荐
老马啸西风11 分钟前
Neo4j GDS-09-neo4j GDS 库中路径搜索算法实现
网络·数据库·算法·云原生·中间件·neo4j·图数据库
海晨忆22 分钟前
【Vue】v-if和v-show的区别
前端·javascript·vue.js·v-show·v-if
XY.散人38 分钟前
初识Redis · list和hash类型
数据库·redis·哈希算法
Arbori_2621538 分钟前
Oracle WITH 子句(也称为 公共表表达式,Common Table Expression,CTE)
数据库·oracle
1024小神1 小时前
在GitHub action中使用添加项目中配置文件的值为环境变量
前端·javascript
Tapdata1 小时前
拒绝停服, 随时回退:Sybase 到 Postgresql 的无缝数据库双向迁移方案
数据库
齐尹秦1 小时前
CSS 列表样式学习笔记
前端
Mnxj1 小时前
渐变边框设计
前端
用户7678797737321 小时前
由Umi升级到Next方案
前端·next.js
moxiaoran57531 小时前
mysql自动赋值
数据库·mysql