如何解决我对较大偏移量的 Sequelize 分页响应缓慢
我有关于产品的大量数据,我猜有 140 个字段分成不同的表。 当我选择第一页数据时它工作正常,但当我选择第 19 或 20 页时,它变得非常慢。
当我请求 Page=1 和 pageSize=100 时,我会在 35 秒内得到响应。 但是当我增加页码时说 19 它在 8 分钟或更长时间内响应。 指导我一些最佳和更专业的方式。 任何提示将不胜感激。
我的 API 处理程序有点像
const page = req.query.page || 1
const pageSize = req.query.pageSize || 30
try {
const data = await BasicProductDetail.findAll({
include: [
{ model: AdditionalProductDetail },{ model: Catalog },{ model: ImageDetail },{ model: Manufacturer },{ model: Measurement },{ model: PriceAndcost },{ model: ProductClass },{ model: Selling },{ model: UPC },{ model: Usage }
],limit : pageSize,offset : (page - 1) * pageSize,order : [ ['id','ASC']]
})
const count = await BasicProductDetail.count({ })
res.json({
data: data,count : count
})
} catch (error) {
console.log(error)
return res.status(500).send(Something Went Wrong!!!)
}
}```
=================================
解决方法
几个建议。
- 您可以使用 findAndCountAll 方法,而不是使用两个不同的查询。它将返回行数据和计数。
- 确保每个模型都完成了正确的索引
- 尝试指定一组所需的属性,而不是提取所有属性。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。