首页 > 解决方案 > Sequelize "raw = true" 用点更改 json 模型属性名称

问题描述

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

const content = await db.Content.findOne({
    where: {
        permalink: req.params.permalink
    },
    include: [{
        model: db.ContentImages
    }]
    raw: true
});

如您所知raw:true,将 SequelizeInstance 隐蔽到对象模型。在这一点上我有一些问题。

如果我使用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
  }
}

另一个问题,我有多个内容图像,如果我使用上面第一个示例,它只返回第一个内容图像。

标签: node.jssequelize.js

解决方案


您正在考虑它有点倒退 - 当您使用raw: true它时,它不会将它从 JSON 对象转换为模型实例。

如果您考虑 SQL 结果的结构,它们总是平淡无奇。这意味着对于有一个基本记录链接到多个子项的连接(Content -< ContentImages在这种情况下),SQL 结果将为每个子项重复基本记录的信息。Sequelize 会将其解析为 JSON 对象,这就是您在问题的第一个示例中看到的内容。如果您省略,raw: true那么它将更进一步并将其解析为您的模型实例。然后,您可以调用Model.toJSON()以获取已解析对象的 JSON 表示。

鉴于上述情况,如果您要获取大量子项,那么将数据放入两个查询而不是一个查询会更有效,因此您不必将重复数据发送到客户端。


推荐阅读