Post 多个项目/一个包含 Express & Postman 的数组

Post Multiple items / an array with Express & Postman

不幸的是,我在 post 一个阵列到我的 Express 服务器时遇到了问题。 我 post 一个项目,如果它存在于数据库中,它将被删除。

我的代码:

item.routes.js

module.exports = app => {
    
  const item = require("../controllers/item.controller.js");

  app.post("/itemr", item.IsReserved);
};

item.controller.js

const Item = require("../models/item.model.js");

exports.IsReserved = (req, res) => {
  // Validate request
  if (!req.body) {
    res.status(400).send({
      message: "Content can not be empty!"
    });
  }

  const item = new Item({
    itemId: req.body.assetId,
    botId: req.body.botId,
  });

  Item.IsReserved(item, (err, data) => {
    if (err)
      res.status(500).send({
        message:
          err.message || "Some error occurred while creating the Item(db)."
      });
    else res.send(data);
  });
};

item.model.js

const sql = require("./db.js");

Item.IsReserved = (RItem, result) => {
    sql.query(`SELECT * FROM ReservedItems WHERE itemId = "${RItem.itemId}"`, (err, res) => {
        if(res.length){
            sql.query(`DELETE FROM ReservedItems WHERE itemId = "${RItem.itemId}"`, (err, res) => {
                if (err) {
                    console.log("error: ", err);
                    result(err, null);
                    return;
                }
                result(null, { id: res.insertId, ...RItem });
            });
        }
        else{
            result(null, { message: "nothing to do"});
        }
    });
};


module.exports = Item;

单个项目与这样的 post 搭配效果很好:

{
   "assetId" : 3,
   "botId" : "1"
}

但是如果我想像这样插入多个项目:

[
    {
        "assetId" : 3,
        "botId" : "1"
        },
        {
        "assetId" : 4,
        "botId" : "1"
    }
]

结果是“无事可做”...

我的 sql 日志显示:Query SELECT * FROM ReservedItems WHERE itemId = "undefined"

我在这里看到另一个 post 有类似的问题,但我不知道如何在我的代码中实现类似“.create()”的东西来识别多个项目。

我将非常感谢您的每一个回答!

有很多方法可以解决您的问题:)

首先,在您的控制器中,这是不可能的,因为您在请求负载中发送了一组项目。所以你还需要定义一个数组:

  const items = req.body.map((item) => new Item({
    itemId: item.assetId,
    botId: item.botId,
  });

由于您的方法 IsReserved 仅处理 1 个项目,您可以使用 Promise.all 应用修改。像这样:

Promise.all( items.map( (item) => Item.isReserved(item)))
.then( (result) => ...do something here)
.catch( (error) => ...do something else here)

另一种方法是更改​​ SQL 语句并使用 WHERE IN

SELECT * FROM ReservedItems WHERE itemId IN (itemid1, itemid2...)

这将为您提供一组项目,然后您可以用相同的方式删除这些项目。在性能方面似乎更好。

我还建议使用 async/await 语法,因为它更容易阅读包含承诺的代码