database - Mongo错误QueryExceededMemoryLimitNoDiskUseAllowed

标签 database mongodb mongodb-query ubuntu-18.04

得到这个错误,当我使用这个查询时:

db2.collection('candata')
.aggregate([{$sort:{time:-1}},{$group:{_id:{batteryId:"$batteryId"},soctime:{$first:"$time"},GPSStatus:{$first:"$GPSStatus"},CANStatus:{$first:"$CANStatus"},soc: { $first : "$socpercentage" },charging_status: { $first : "$charging_status" },status: { $first : "$status" }}},{$sort:{'_id.batteryId':1}},{$lookup:{from : "swap_table",localField : "_id.batteryId",foreignField:"batteryId",as:"swap"}},{$lookup:{from : "battery_status_table",localField : "_id.batteryId",foreignField:"batteryId",as:"battery_statustb"}}])

我需要做什么改变?我不想改变查询,那么如何增加这个限制,或者我需要去一些数据归档的方法?

最佳答案

添加 allowDiskUse 并在查询结束时将其设置为 true,这样它就变成如下所示:

 db2.collection('candata')
.aggregate([{$sort:{time:-1}},{$group:{_id:{batteryId:"$batteryId"},soctime:{$first:"$time"},GPSStatus:{$first:"$GPSStatus"},CANStatus:{$first:"$CANStatus"},soc: { $first : "$socpercentage" },charging_status: { $first : "$charging_status" },status: { $first : "$status" }}},{$sort:{'_id.batteryId':1}},{$lookup:{from : "swap_table",localField : "_id.batteryId",foreignField:"batteryId",as:"swap"}},{$lookup:{from : "battery_status_table",localField : "_id.batteryId",foreignField:"batteryId",as:"battery_statustb"}}]).allowDiskUse(true)

关于database - Mongo错误QueryExceededMemoryLimitNoDiskUseAllowed,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66346206/

相关文章:

java - 我在访问日期查询时遇到错误

python - django-nonrel syncdb 和 mongodb : pymongo. 错误。OperationFailure

node.js - 使用 MongoDB Streams 观看文档创建

java - 如何使用 Java 从 MongoDB 3.4 版本获取数据?

Mongodb - 根据其他字段值添加额外字段

mongodb - 查询 MongoDB 中的内部数组大小

php - 使用 Cocoa 查询数据库

java - Mybatis中的foreach是硬解析还是软解析?

database - Mongodb 复制(辅助服务器)

mongodb - 2 个文档在 MongoDB 中合并