微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

我对较大偏移量的 Sequelize 分页响应缓慢

如何解决我对较大偏移量的 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 举报,一经查实,本站将立刻删除。