【问题标题】:Count related models and limit using Sequelize使用 Sequelize 计算相关模型和限制
【发布时间】:2022-02-03 16:07:00
【问题描述】:

我有一个有效的 Sequelize 查询,它以这种方式获取模型,包括相关模型的数量:

    const elements = await ElementsModel.findAll({
      attributes: {
        include: [[Sequelize.fn("COUNT", Sequelize.col("related.id")), "related_total"]]
      },
      include: [
        {
          model: RelatedModel,
          attributes: [],
        }
      ],
      group: ['elements.id']
    });

查询效果很好,但现在我需要包含一个 offsetlimit 子句用于分页,例如:

    const elements = await ElementsModel.findAll({
      limit: 10,
      offset: 0,
      attributes: {
        include: [[Sequelize.fn("COUNT", Sequelize.col("related.id")), "related_total"]]
      },
      include: [
        {
          model: RelatedModel,
          attributes: [],
        }
      ],
      group: ['elements.id']
    });

由于包含字段和limit 子句的组合,查询中断并且不再工作,生成无效查询,例如:

SELECT `elements`.* 
FROM (
  SELECT `elements`.`id`, `elements`.`type`, COUNT(`related`.`coupon_id`) AS `related_total` 
  FROM `elements` AS `elements` GROUP BY `elements`.`id` LIMIT 0, 20
) AS `elements` 
LEFT OUTER JOIN `related` AS `related` ON `elements`.`id` = `related`.`elements_id`;

Sequelize 有什么方法可以解决这个问题?

【问题讨论】:

    标签: javascript node.js sequelize.js


    【解决方案1】:

    要正确使用limitoffset 选项,您需要使用带有Sequelize.literal 而不是Sequelize.fn 的子查询,并完全删除includegroup 选项。

    const elements = await ElementsModel.findAll({
          limit: 10,
          offset: 0,
          attributes: {
            include: [
      // correct a table name and fields if needed
      [Sequelize.literal("(SELECT COUNT(*) FROM Related where Related.elementId=Elements.id)"), "related_total"]
          ]
          },
        });
    

    【讨论】:

    • 包含的属性代码中有一个错字,但是是的,使用文字子查询解决了这个问题。谢谢!
    猜你喜欢
    • 1970-01-01
    • 2019-02-05
    • 2016-10-15
    • 2019-09-09
    • 2011-07-06
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-12-08
    相关资源
    最近更新 更多