egg3.0连接egg-mongoose操作数据库,删除一条数据、批量删除数据

本文展示了在Egg.js框架下如何定义服务(service)和控制器(controller)来实现单条及批量删除数据操作。通过`ctx.model.Role.deleteOne()`和`ctx.model.Role.remove()`方法删除MongoDB中的Role数据,并使用Postman测试删除接口的效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

删除一条数据

定义service

app\service\role.js

  async delItem() {
    const { ctx } = this;
    let results;
    await ctx.model.Role.deleteOne({ name: 'test-S3' }).then(res => {
      console.log('results-del-success', res);
      results = res?.deletedCount > 0;
    }).catch(err => {
      console.log('results-del-fail', err);
      results = false;
    });
    return results;
  }

定义controller

  async del() {
    const { ctx } = this;
    const res = await ctx.service.role.delItem();
    console.log('controller', res);
    ctx.body = {
      code: 0,
    };
  }

成功删除一条

在这里插入图片描述

在这里插入图片描述

成功删除0条

在这里插入图片描述

在这里插入图片描述

批量删除数据

  async bitch_del() {
    const { ctx } = this;
    let results;
    await ctx.model.Role.remove({
      name: { $in: [ 'test-S', 'test-S1' ] },
    }).then(res => {
      console.log('results-del_bitch-success', res);
      results = res?.deletedCount > 0;
    }).catch(err => {
      console.log('results-del_bitch-fail', err);
      results = false;
    });
    return results;
  }

删除前数据
在这里插入图片描述
postman调用删除接口
在这里插入图片描述

删除后数据查询
在这里插入图片描述

定义路由

router.js

'use strict';

/**
 * @param {Egg.Application} app - egg application
 */
module.exports = app => {
  const { router, controller } = app;
  router.get('/', controller.home.index);
  router.get('/role', controller.role.index);
  router.post('/role/add', controller.role.add);
  router.delete('/role/del', controller.role.del);
  router.post('/roles', controller.rolePost.index);
};

edge浏览器关于postwoman的使用

在这里插入图片描述

在这里插入图片描述

本文代码截取文件内的某个函数。可结合同一专栏其他egg文章内容一同查看。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值