gpt4 book ai didi

node.js - Sequelize "raw = true"使用点更改 json 模型属性名称

转载 作者:行者123 更新时间:2023-12-03 22:25:13 25 4
gpt4 key购买 nike

我有 Content 模型,它有很多子 ContentImage 项目,像这样;

const content = await db.Content.findOne({
where: {
permalink: req.params.permalink
},
include: [{
model: db.ContentImages
}]
raw: true
});
如您所知, raw:true 将 SequelizeInstance 转换为 Object 模型。在这一点上我有一些问题。
如果我使用 raw:true ,json 模型会这样显示我;
{
"id": 4706,
"name": "Content Title",
"content": "Content detail",
"t_content_images.id": 7633,
"t_content_images.content_id": 4706,
"t_content_images.image": "content-image-1.jpg",
"t_content_images.order_no": 1
}
因为expressjs,我需要像这个模型而不是SequelizeInstance;
{
"id": 4706,
"name": "Content Title",
"content": "Content detail",
"t_content_images": {
"id": 7633,
"content_id": 4706,
"image": "content-image-1.jpg",
"order_no": 1
}
}
另一个问题,我有多个内容图像,如果我使用上面的第一个示例,它只会返回第一个内容图像。

最佳答案

您有点倒退了 - 当您使用 raw: true 时,它​​不会将其从 JSON 对象转换为模型实例。
如果您考虑一下 SQL 结果的结构,它们总是平坦的。这意味着对于将一个基本记录链接到多个子项(在本例中为 Content -< ContentImages)的连接,SQL 结果将重复每个子项的基本记录的信息。 Sequelize 会将其解析为 JSON 对象,这就是您在问题的第一个示例中看到的内容。如果您省略 raw: true,那么它将更进一步并将其解析为您的模型实例。然后,您可以调用 Model.toJSON() 来获取解析对象的 JSON 表示。
鉴于上述情况,如果您要获取大量子项,那么将数据放入两个查询而不是一个查询中会更有效,这样您就不必将重复数据发送到客户端。

关于node.js - Sequelize "raw = true"使用点更改 json 模型属性名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64229217/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com