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

oddrine-如何生成查找查询

如何解决oddrine-如何生成查找查询

我有一个symfony 5项目,其中mongodb作为数据库,oddrine odm。

一切看起来都不错,但事实是,在一个庞大的集合中,每个查询都要花很多时间。索引看起来不错。

在对此进行调查之后,我注意到使用以下查询之类的查询大约需要0.5秒(考虑到数据大小和我们的需求也可以):

db.getCollection('Logs').find({clientId: 1234567}).sort({'_id': 1});

然后,我检查了api平台如何生成查询,它是如何生成查询的,从最终结果的角度来看,这基本上是相同的:

db.getCollection('Logs').runcommand({"aggregate":"Logs","pipeline":[{"$match":{"clientId":1234567}},{"$sort":{"_id":1}}],"allowdiskUse":false,"cursor":{}})

问题在于第二个变体执行大约需要115秒。

为什么第二个选项这么慢(我猜它没有使用索引或其他东西)? 另外...我可以以某种方式“指导”使用find而不是runcommand的原则(项目建立在https://api-platform.com/上,删除该原则将需要放弃该原则,我们对此非常喜欢,因此除非绝对必要,否则我希望保留它)?

更新:经过进一步调查,我发现api平台实际上是罪魁祸首,该理论认会生成find;相应地编辑了问题。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。