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 语法,因为它更容易阅读包含承诺的代码
不幸的是,我在 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 语法,因为它更容易阅读包含承诺的代码