草庐IT

query_index

全部标签

MongoDB: "Malformed geo query"多边形上有 $geoIntersect

我在一个集合中有事件,每个事件都包含一个所需的位置,设置一个GeoJSON多边形。我在另一个集合中也有服务提供商,也有一个GeoJSON多边形,指示他们可以交付的区域。对于给定的服务提供商,我试图列出兼容区域中的所有事件。但是,我得到这个错误:Malformedgeoquery:{$geoIntersects:{$geometry:{type:"Polygon",coordinates:[[[-31.59327575763251,115.8574693000001],[-31.59676306691357,115.9162469300458],[-31.60715789289806,1

MongoDB 聚合 : How to query a limited amount of "top" documents per group?

假设我有一个包含员工文档的MongoDB集合:{name:"JohnDoe",department:"Finance",salary:100}如何查询每个部门薪资最高的X名员工?编辑为了让自己更清楚一点,我是这样想的:db.collection.aggregate({$sort:{salary:-1}},{$group:{_id:"$department"employees:{$addToSet:"$name"}},{$project:{employees:{$slice:X}}})但这行不通有两个原因:1.$addToSet不保证输出集的任何顺序(至少根据documentation)

MongoDB 聚合框架 : group query

我希望使用mongoDB的聚合框架获得特定的查询。我想我需要$group和$addToSet运算符,但我对要使用的正确查询感到困惑。这是文章合集:/*0*/{"_id":4,"author":"KevinVanhove","book":{"order":500,"title":"HTML","url":"html"},"chapter":{"img":"navChapter-logo","order":500,"title":"W3C","url":"w3c"},"featured":0,"heading":[{"title":"title1","_id":ObjectId("5313

java - 蒙戈 : aggregation and indexing with Java - optimal way

只是想找到聚合的最佳方式,但不确定在聚合时我需要如何处理索引。如果有人对此有经验并且可能可以分享想法或经验...情况:拥有数百万条记录的MondoDB集合,让它成为一些日志(每天大约3-5百万条)所有实现均使用Java7和Mongo聚合完成Mongo集合中的日志记录如下所示:{"_id":"","timestamp":"","userId":"","userIp":"","country":"","city":"","applicationName":""}我有不同的基于日志数据的报告。我几乎需要按每个字段和字段组合创建报告,甚至更多所有聚合都应该按每日/每周/每月完成问题:我应该如何

node.js - MongoError : can't find any special indices: 2d (needs index), 2dsphere(需要索引)$nearSphere

这是我的第一个问题,所以如果问得不是很好或者我的英语不好,请耐心等待我。我正在尝试在Node.js中的MongoDB中执行地理空间查询。这个查询工作得很好collection.find({loc:{$geoWithin:{$centerSphere:[[point.coordinates[0],point.coordinates[1]],getRadiusMeters(radius)]}}})但是当我尝试对$nearSphere做同样的事情时:collection.find({loc:{$nearSphere:{$geometry:{type:"Point",coordinates:[

c# - 使用非通用 EQ-Query 从集合中删除文档

我正在尝试使用非通用EQ-Query从我的集合中删除文档,但它没有删除任何内容。使用通用的EQ-Query,文档被成功删除。这是我存储在MongoDB中的对象。publicclassUserDto{publicintId{get;set;}publicstringFirstName{get;set;}publicstringLastName{get;set;}publicstringUserName{get;set;}}这是我如何从集合中删除文档的示例代码。varcollection=database.GetCollection(typeof(UserDto).Name);varsin

node.js - Mongoose :Query#exec 的目的是什么

Query#execMongoose的方法表示它执行查询并返回一个Promise对象。我不明白的是为什么这是必需的,因为已经有一个Query#then方法。具体例子:考虑一些简单的模型varFoo=mongoose.model("Foo",{name:String});有什么区别Foo.find().then(function(res){/*..*/},function(err){/*..*/});和Foo.find().exec().then(function(res){/*..*/},function(err){/*..*/});两者似乎都能正常工作。

php - 学说 2 ODM : Querying ID field with MongoRegex with LIKE

我有一个更大的项目,在Symfony上下文中使用Doctrine2ODM。给定一个简单的ODM实体(XML定义):我想在_id字段上使用MongoRegex表达式查询App文档。现在,我知道“string与MongoId”问题-我们所有的ID都是正确的字符串。当我尝试通过MongoDBshell执行此操作时(使用Robomongo作为GUI);一切都很好,因为这个表达式成功返回了我正在搜索的对象:App.find({'_id':/^ad.*$/i})但是在PHP上下文中它是不同的。Doctrine2ODM中有一种特殊的逻辑,它对待标识符字段上的equals()搜索不同于普通的equal

node.js - 宇宙数据库 : MongoDB sort query returning blank resultset

我正在使用Mongoose.js4.11.6Node.js6.0。我有一个用户文档,如下所示-varUserSchema=newSchema({name:{type:String,default:''},email:{type:String,default:''},phone:{type:String,default:''},hashed_password:{type:String,default:''},role:{type:String,default:''},created_at:{type:Date,default:Date.now}});我正在运行以下mongoose查询-U

node.js - MongoDB NodeJS 驱动程序 : Duplicate key `E11000` extract index name

在使用MongoDBNodeJS驱动程序(甚至mongoose)时,插入新文档时,可能会返回一个E11000错误,表明发生了重复键冲突。如果我要插入的集合有多个唯一索引并且我想确定其中一个被命中(例如,通知用户他的用户名和/或电子邮件已被占用)怎么办?这是插入具有冲突索引的文档后引发的错误:{"name":"MongoError","message":"E11000duplicatekeyerrorindex:db.users.$_id_dupkey:{:\"blucell\"}","driver":true,"index":0,"code":11000,"errmsg":"E1100