1

您好,我正在尝试id从文档中删除嵌套数组对象,但它没有被删除。虽然我收到消息"Deleted"

我有一个结构是: -

{
    "admins": {
        "users": [
            "5d0364048db4957100f33fea" //<===want to delete this relational id
        ],
        "email": "1cf1eede89@himail.online",
        "password": "$2a$10$vHyGxX9P.t0/ybKcmIzkc.ZCX18oHaVnvTgJIWA2gTNzJ3TCdXS4a",
    "_id": "5d0339d5b4b28b6ddff06802",
    "companyName": "GH",
    "__v": 0
}

我想users _id从数组中删除。

我试过了,但它没有被删除。

router.delete('/userDelete/:uId', checkAuth , (req, res, next) =>{
    if(req.userData.role2 === 'admin') {
        Admin.findOneAndUpdate({ _id: req.params.userId },{ $pull: { 'admins.users': req.params.uId}}) 
        .exec()
        .then(result => {
            res.status(200).send(["Deleted"]);
        })
        .catch(err =>{
        if (err.code == 500)
                    res.status(500).send(["Didn't get deleted"]);
        else
            return next(err);
        });

控制器是这样的:-

var admin = new Admin();
    admin.companyName = req.body.companyName;
    admin.admins = {
                    email : req.body.email,
                    password: req.body.password,
                    users : [] 
    };

我被困在这里,我必须在路线上做些什么改变?

编辑:- DB是这样的 D B

4

3 回答 3

1

问题就在这里Admin.findOneAndUpdate({ _id: req.params.userId }

req.params.userIdundefined,因为它不存在于您的路径中。req.params对象只拥有一个属性,uId。所以你的查询没有找到任何数据。
req.params.userId如果您的方法路线有这样的形式,那将是有价值的router.delete('/userDelete/:userId/:uId)
因此,您可以在删除请求的 url 中添加 userId 并通过req.params对象访问它。新的网址应该是这样的

/userDelete/userId/uId

(例如)

userDelete/5d0339d5b4b28b6ddff06802/5d0364048db4957100f33fea
于 2019-06-17T12:23:35.073 回答
0

尝试在这里硬编码你的 id

Admin.findOneAndUpdate({ _id: req.params.userId },{ $pull: { 'admins.users': "5d0364048db4957100f33fea"}}) 

如果它正在工作,那么做

req.params.uId.toString()
于 2019-06-17T11:48:53.187 回答
0

尝试在数组的架构本身中将“_id”标记为 false。例如,在您的架构中,将“_id”标记为 false,如下所示:

admin: {
  type: Object,
  users: [{
    _id: false
  }]
}
.
.
//rest of the schema
于 2019-06-19T09:30:49.020 回答