【mongoose8.x】mongoose8.x入门教程(二):express中mongoose的链接

mongoose是nodejs的框架,所以我们需要在nodejs的后端框架中才能使用,比如express,koa等。

项目准备

新建一个express(或koa)的项目

修改相关的默认文件配置,启动项目

看到这样的界面,就说明我们项目搭建成功了。

下面,我们来引入mongoose的操作

根据官网的文档demo进行操作即可:https://mongoosejs.com/docs/index.html

mongoose的链接

js 复制代码
// getting-started.js
const mongoose = require("mongoose");
mongoose.connect("mongodb://127.0.0.1:27017/vueshopapp");
const db = mongoose.connection;
db.on("error", console.error.bind(console, "connection error:"));
db.once("open", function () {
  // we're connected!
  console.log("Connected successfully");
});

module.exports = mongoose;

创建一个collection

js 复制代码
const mongoose = require("..");
const { Schema } = mongoose;

const GoodsSchema = new Schema({
  productId: { type: String, required: true },
  productName: { type: String, required: true },
  salePrice: { type: Number, required: true },
  productImage: { type: String, required: true },
  productUrl: String,
});

const Goods = mongoose.model("Good", GoodsSchema);

module.exports = Goods;

collections的使用

  • 查询商品列表
js 复制代码
/* GET Goods page. */
router.get("/list", async function (req, res, next) {
  try {
    const goods = await Goods.find({});
    res.json(Result.success(goods));
  } catch (err) {
    handleError(err);
    res.json(Result.error("查询失败!"));
  }
});

注意这里的语法格式,mongoose8.x里面的find不支持回调函数了,需要使用async/await来写

查询数据效果

当然也可以在apifox或其他的接口调试工具中使用

封装下返回数据

一般,我们在做项目的时候,后端返回给前端的数据格式是一致的,所以有必要封装下返回格式

js 复制代码
class Result {
  static success(data = "") {
    return {
      code: 10000,
      success: true,
      data: data,
    };
  }

  static error() {
    return {
      code: 10001,
      success: false,
      data: null,
    };
  }
}

module.exports = Result;

可以自行扩展上面的Result。

新增一个商品

js 复制代码
// 添加商品
router.post("/add", async function (req, res, next) {
  try {
    const goods = new Goods(req.body);
    console.log("🚀 ~ :25 ~ goods:", goods);
    await goods.save();
    res.json(Result.success("添加成功!"));
  } catch (err) {
    handleError(err);
    res.json(Result.error("添加失败!"));
  }
});

一般是post请求,这下我们必须在apifox等工具中进行调试了

后端日志:

可以从页面中查看到,新数据被新增进去了

在compass中,刷新数据后就看到了刚才添加的数据,也就表明数据持久化完成了。

相关推荐
前端小盆友10 小时前
从零实现一个GPT 【React + Express】--- 【5】实现网页生成能力
gpt·react.js·express
搞前端的小菜16 小时前
从零实现一个GPT 【React + Express】--- 【2】实现对话流和停止生成
gpt·react.js·express
前端小盆友2 天前
从零实现一个GPT 【React + Express】--- 【4】实现文生图的功能
react.js·chatgpt·express
实习生小黄2 天前
express 连接在线数据库踩坑
node.js·express
搞前端的小菜3 天前
从零实现一个GPT 【React + Express】--- 【1】初始化前后端项目,实现模型接入+SSE
gpt·react.js·express
水冗水孚19 天前
express使用node-schedule实现定时任务,比如定时清理文件夹中的文件写入日志功能
javascript·node.js·express
羽沢3119 天前
nodejs中Express框架的基本使用
express
gongzemin21 天前
前端根据文件流渲染 PDF 和 DOCX 文件
前端·vue.js·express
十月ooOO22 天前
Express.js 在 ts 模式下运行 npm run dev 的时候无法找到引入项的原因
javascript·npm·express