老师,这里不能直接拿 ES 里的商品数据吗

        // 通过 collect 函数将返回结果转为集合,并通过集合的 pluck 方法取到返回的商品 ID 数组
        $productIds = collect($result['hits']['hits'])->pluck('_id')->all();
        // 通过 whereIn 方法从数据库中读取商品数据
        $products = Product::query()
            ->whereIn('id', $productIds)
            ->get();

ES 里面不是有商品数据吗?为什么还要根据 Id 重新去查一遍呢

《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
leo
最佳答案

假如由于某种原因更新商品数据的队列没有正确运行,或者有较大的延迟,直接从 ES 取则可能取到不准确的数据

6年前 评论
讨论数量: 4
leo

假如由于某种原因更新商品数据的队列没有正确运行,或者有较大的延迟,直接从 ES 取则可能取到不准确的数据

6年前 评论

@leo 如果这种情况出现的话,岂不是搜索的话也搜不到最新的?

6年前 评论
leo

@18874127314 是有这种可能

6年前 评论
happyqian_ah

最大的问题是不能使用关联吧。不然,关系型数据库早就被文档型数据库代替了

6年前 评论