草庐IT

text_field

全部标签

node.js - Mongoose 两次定义字段时抛出 `Field is not in schema` 错误

我正在使用Nodev0.10.31和mongoose@3.8.22。我想我遇到了一个在特定事情发生时出现的错误。此错误的影响使我无法在同一架构上拥有字段“name”和“father.name.full”。这就是我定义模式的方式:'usestrict';varmongoose=require('mongoose');mongoose.connect('mongodb://localhost/myapp');varPersonSchema=newmongoose.Schema({name:{type:mongoose.Schema.Types.ObjectId,ref:'Name',//i

mongodb - 使用 Meteor Mongo 2.6.7 进行文本搜索显示 "text search not enabled"

我有Mongo版本2.6.7(我使用db.version()进行了检查),并且我在本地服务器上进行了按预期工作的文本搜索。但是,当我部署到实时meteor站点时,我在日志中收到一条错误消息,内容为“MongoError:未启用文本搜索”。我不确定这是为什么,因为这应该是安装好的 最佳答案 .meteor运行旧版本的MongoDB(2.4.10?),默认情况下不启用“文本搜索”。有关更多信息,请查看:https://github.com/meteor/meteor/issues/5128

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

mongodb - 蒙戈 : Find docs where field is a prefix of a string literal without using $where

我想找到给定字段是输入值前缀的所有文档。在SQL中它看起来像这样:...whereinput_valuelikeconcat(field,'%')我想在Mongo2.4.8中执行此操作(最好是)不使用$where。使用$where很容易,但我不能使用$where因为我想使用管道所以我可以使用$project来派生一些领域。和apparently您不能在$match管道中使用$where。据我所知,您不能在普通find()projection中使用管道$project-ion运算符-啊。 最佳答案 一种方法是构造一个$regex图案。

MongoDB $text 运算符匹配文档,其中搜索字符串是子字符串

我知道$text运算符不适用于正则表达式...但我需要一些搜索才能按以下方式工作。文件:{"field1":"一些内容","field2:""另一个内容"}{"field1":"还有一个内容","field2":"最终内容"}如果我们按字符串"yeano"搜索,两个文档都应该在结果中,因为ye出现在第二个文档中,而ano出现在第一个。由于大小写/变音符号不敏感,我们将非常感谢使用$text运算符的解决方法。我也会接受行为不相等但接近的东西。主要关注的是效率,因为我已经有一个O(nlgn)的解决方案,但这对于搜索来说非常昂贵...... 最佳答案

Mongodb $near、$geoWithin 和 $text

最初我想支持带有geo$near功能的mongodb文本搜索。后来意识到这两个不能一起使用,因为都需要索引。后来我决定改用$geoWithin。但是,结果不像$near那样按距离排序。我想知道是否有任何方法可以按“距离”对$geoWithin返回的结果进行排序? 最佳答案 $geoWithin运算符不返回排序结果。因此,MongoDB可以比地理空间$near或$nearSphere查询更快地返回$geoWithin查询,后者对结果进行排序。所以简而言之,使用$near或$nearSphere以便您可以获得排序结果。见docs:The

PHP MongoDB `fields` 参数不工作

根据php文档http://php.net/manual/en/mongocollection.findone.php,以下查询应仅返回文档的emails字段。然而它把它们全部归还了!我发现无论我在fields数组中放入什么,它都会返回所有字段。$row=$Entities->findOne(["emails.email"=>$address],array("emails"=>1));知道哪里出了问题吗?我在Ubuntu16.04上使用php7。来自composer.json的信息"packages":[{"name":"mongodb/mongodb","version":"1.0.

MongoDB : Find duplicate when field type is not the same

即使字段类型不同,我如何检测重复?{id:1,price:5}{id:2,price:"6"}{id:3,price:"5"}所以重复是{id:1,price:5}{id:3,price:"5"} 最佳答案 您可以使用$substr将索引从0到-1(字符串的其余部分)转换为字符串。:db.duplicates.aggregate([{"$project":{id:1,price:{$substr:["$price",0,-1]}}},{"$group":{"_id":"$price","count":{"$sum":1},"item

mongodb - Mongo 聚合 : add conditional fields

我有一个包含多个阶段的聚合管道。在这些阶段之后,简化的结果是这样的:{feature1:[{random:125}],feature2:[{a:"fsfs",val:[125]}]}我想添加一个新字段type,它是根据这些条件设置的:feature1.size>0和feature2.size>0然后输入='back'feature2.size>0然后输入='front'否则类型='none'feature1和feature2数组的内容并不重要,类型取决于数组是否被填充。我的想法是使用带有$cond运算符的$addFields阶段,但我无法弄清楚语法。 最佳答

mongodb aggregation : if value of two fields match, 将相应字典的另一个字段的值添加到新字段

在三个集合中使用聚合查找后,我得到以下结果。[{_id:"henten",location:"someplace",devices:[{"d_id":'d0001',"z_id":'z2001'},{"d_id":'d0002',"z_id":'z2002'}],store:[{"z_name":'vera',"z_id":'z2001'},{"z_name":'ghora',"z_id":'z2002'}]}]如果devices.z_id与store.z_id匹配,我需要将“d_id”的值作为数组推送到“store”的字典中,并添加到名为“DID”的新字段中。我尝试了以下方法:{$a