使用 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']
});
查询效果很好,但现在我需要包含一个 offset
和 limit
分页子句,例如:
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 处理这个问题吗?
要正确使用 limit
和 offset
选项,您需要使用带有 Sequelize.literal
的子查询而不是 Sequelize.fn
并删除 include
和 group
个选项。
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"]
]
},
});
我有一个可用的 Sequelize 查询,它以这种方式获取模型,包括相关模型的计数:
const elements = await ElementsModel.findAll({
attributes: {
include: [[Sequelize.fn("COUNT", Sequelize.col("related.id")), "related_total"]]
},
include: [
{
model: RelatedModel,
attributes: [],
}
],
group: ['elements.id']
});
查询效果很好,但现在我需要包含一个 offset
和 limit
分页子句,例如:
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 处理这个问题吗?
要正确使用 limit
和 offset
选项,您需要使用带有 Sequelize.literal
的子查询而不是 Sequelize.fn
并删除 include
和 group
个选项。
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"]
]
},
});