Express及mongoose搭建数据库(增删改查)

express是什么?

Express.js 是一个基于 Node.js 平台的 Web 应用程序框架,它旨在帮助开发者轻松构建和管理 Web 服务和应用程序。Express 提供了许多强大的功能,使得创建可扩展、灵活且高性能的 Web 应用变得相对容易。

安装Express步骤

确保已经安装了 Node.js 和 npm,使用npm创建express项目

javascript 复制代码
// 步骤一,安装express包
npm i express -g

// 步骤二,安装express-generator包
npm i express-generator -g

使用express-generator生成express项目

javascript 复制代码
// node-api是项目名称
express --no-view node-api

// 使用cd进入创建的项目文件,例如
cd node-api

//进入项目文件后初始化项目
npm i

配置跨域,安装cors模块,可参照

javascript 复制代码
// 安装命令
npm i cors --save

// 在app.js文件中引入cors模块并使用,例如
var express = require("express");
var path = require("path");

..........
..........

// 在这里引入即可
var cors = require("cors");

var indexRouter = require("./routes/index");
var usersRouter = require("./routes/users");

var app = express();
// 在这里使用
app.use(cors());

.........
.........

module.exports = app;

安装nodemon这个包

javascript 复制代码
npm i nodemon -D

然后修改package.json中的配置,修改成nodemon

javascript 复制代码
 "scripts": {
    "start": "nodemon ./bin/www"
  },

经过此步骤后,查看是否能启动这个服务器

javascript 复制代码
// 启动命令/控制台启动
nodemon

安装mongoose步骤

进入mongoose官网:Mongoose.js中文网

安装mongoose

javascript 复制代码
npm i mongoose -S

在mongoose.com中将以下代码放在app.js中

javascript 复制代码
// app.js文件
var express = require("express");
var path = require("path");

..........
..........

var cors = require("cors");
// 在此处引入
const mongoose = require('mongoose');
mongoose.connect('mongodb://127.0.0.1/数据库集合名');

var indexRouter = require("./routes/index");
var usersRouter = require("./routes/users");

var app = express();
app.use(cors());

.........
.........

module.exports = app;

在routes/index.js文件中创建集合配置字段类型

javascript 复制代码
..........

const mongoose = require("mongoose");
const Product = mongoose.model("Product", { name: String, price: Number });

// 使用这行命令添加几条数据/记得注释掉(不然会一直添加 )
Product.create({
    name:'板子',
    price:123
})

下面进行功能测试,增删改查

添加数据
javascript 复制代码
// 添加
router.post("/", async function (req, res, next) {
  const product = new Product(req.body);
  const result = await product.save();
  res.json({
    code: 200,
    message: "success",
    data: result,
  });
});
搜索查询分页
javascript 复制代码
// 搜素,排序,分页
router.get("/", async function (req, res, next) {
  const page = req.query.page || 1;
  const limit = req.query.limit || 2;
  const skip = (page - 1) * limit;
  const searchName = req.query.name || "";
  const products = await Product.find()
    .where({ name: searchName })
    .skip(skip)
    .limit(limit)
    .sort({ price: 1 });
  res.json({
    code: 200,
    message: "success",
    data: products,
  });
});
修改数据
javascript 复制代码
// 修改
router.post("/:id", async function (req, res, next) {
  const id = req.params.id;
  await Product.updateOne({ _id: id }, req.body);
  res.json({
    code: 200,
    message: "success",
  });
});
删除数据
javascript 复制代码
// 删除
router.delete("/:id", async function (req, res, next) {
  const id = req.params.id;
  const result = await Product.findOneAndDelete({ _id: id });
  res.json({
    code: 200,
    message: "del success",
  });
});
相关推荐
程序员拂雨1 天前
Express知识框架
node.js·express
layman05283 天前
node.js 实战——餐厅静态主页编写(express+node+ejs+bootstrap)
node.js·bootstrap·express
layman05285 天前
node.js 实战——express图片保存到本地或服务器(七牛云、腾讯云、阿里云)
node.js·express
小妖6668 天前
express 怎么搭建 WebSocket 服务器
websocket·网络协议·express
一袋米扛几楼9815 天前
【前端】从零开始的搭建顺序指南(技术栈:Node.js + Express + MongoDB + React)book-management
前端·node.js·express
layman052815 天前
node.js 实战——从0开始做一个餐厅预订(express+node+ejs+bootstrap)
node.js·express
白昼的星光@16 天前
使用nodeJs的express+axios+cors做代理
express
键盘飞行员17 天前
使用 Node、Express 和 MongoDB 构建一个项目工程
数据库·mongodb·express
烛阴19 天前
Node.js中必备的中间件大全:提升性能、安全与开发效率的秘密武器
javascript·后端·express
kovlistudio23 天前
红宝书第四十七讲:Node.js服务器框架解析:Express vs Koa 完全指南
服务器·前端·javascript·node.js·express