node.js - (MONGODB) 删除父集合时如何删除引用的数据
问题描述
我有两个模式文件夹和模型文件,如下所示..
文件夹架构
const mongoose = require('mongoose')
const {ObjectId} = mongoose.Schema
const folderSchema = new mongoose.Schema({
title:{
type: String,
},
belongsTo:{
type:ObjectId,
ref:"Project"
}
})
module.exports = mongoose.model("Folder",folderSchema)
模型文件架构
const mongoose = require("mongoose");
const {ObjectId} = mongoose.Schema
const modelFileSchema = new mongoose.Schema({
createdAt: {
type: Date,
default: Date.now,
},
name: {
type: String,
required: [true, "Uploaded file must have a name"],
},
image:{
type:String
},
belongsTo:{
type:ObjectId,
ref:"Folder"
}
});
const File = mongoose.model("ModelFile", modelFileSchema);
module.exports = File;
文件夹架构是文件的父架构。删除文件夹时如何从文件架构中删除数据。文件架构中属于正在删除的文件夹的所有数据也必须删除。例如,我有名为 A 的文件夹和引用文件夹 A 的文件 1、2、3。当我删除文件夹 A 时,文件 1、2、3 也必须删除。
下面是我的删除文件夹代码,它只是删除文件夹。文件保留在数据库中。
路线。
router.delete("/folder/delete/:folderId",deleteFolder);
控制器..
exports.deleteFolder = (req,res)=>{
let folderId= req.params.folderId
console.log(folderId);
Folder.findOne({_id:folderId}).then((resp)=>{
console.log(resp._id)
Folder.deleteOne({_id:folderId})
.then(()=>{
res.status(400).json( resp._id + " deleted")
})
.catch((err)=>{
console.log(err.message)
})
}).catch(()=>{
res.send("Folder doesnot exist")
})
}
解决方案
您可以为此使用中间件。
Folder.pre('deleteOne', function(next) {
// Remove all the assignment docs that reference the removed person.
this.model('ModelFile').remove({ _id: this._id }, next);
});
有关更多信息,请参阅这篇文章:在 MongoDB 中删除时自动删除引用对象
推荐阅读
- python - 根据数据框中的其他行值创建列
- aws-fargate - 我们如何在 AWS 中部署 Backstage 应用程序?部署架构工作流程是什么?
- c - C 结构与 Fortran 的互操作
- sympy - 减少 sympy 中的不等式系统
- javascript - 如何使用 javascript 或 css 根据屏幕大小呈现 div
- html - 如何扩展导航栏背景,同时保持元素居中?
- python - 将 2 个具有不同列数的 Pandas 数据框相乘
- security - 使用 hcsshim 将 HNS 端点上的流量限制到特定 IP 地址
- c# - 是随机划分数字的逻辑吗?
- amazon-dynamodb - 使用 Amplify 的 @key 指令创建单个 LSI