问题描述
我有关于产品的大量数据,我猜有 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 方法,而不是使用两个不同的查询。它将返回行数据和计数。
- 确保每个模型都完成了正确的索引
- 尝试指定一组所需的属性,而不是提取所有属性。