使用 Sequelize 计算相关模型和限制

Count related models and limit using Sequelize

我有一个可用的 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 处理这个问题吗?

要正确使用 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"]
      ]
      },
    });