草庐IT

d_values

全部标签

PHP MongoDB 聚合 : how to $sum only when value is greater than 0?

我正在使用PHP访问MongoDB集合,我在其中记录了游戏玩家:{username:"John",stats:{games_played:79,boosters_used:1,crystals:5}},{username:"Bill",stats:{games_played:0,boosters_used:0,crystals:20}},{username:"Jane",stats:{games_played:154,boosters_used:14,crystals:37}},{username:"Sarah",stats:{games_played:22,boosters_used

node.js - Nodejs 和 MongoDB : Unable to return value from a function

varconfig=require('config.json');varmongo=require('mongoskin');vardb=mongo.db(config.connectionString,{native_parser:true});module.exports.getNextSequence=function(name){vartemp;db.collection("counters").findAndModify({_id:name},//query[],//representsasortorderifmultiplematches{$inc:{seq:1}},//u

mongodb - Doctrine/MongoDB : Use key-value pairs instead numeric array

我正在将DoctrineODM与MongoDB结合使用。我有一个这样的“产品模型”:namespaceCms\Model;/**@Document(collection="products")*/classProduct{/**@Id*/private$id;/**@String*/private$title;/**@String*/private$description;/**@Date*/private$createdAt;/**@EmbedMany(targetDocument="Cms\Model\ProductParam")*/private$params;/**@Embed

mongodb - 如何删除 mapReduce 中的 "value"?

我想知道是否可以删除map-reduce中的“value”键,以便最终结果直接包含值而不是在“value”键中。我希望仅使用命令(因此没有Javascript变量等)例如,map-reduce输出通常是[{"_id":0,"value":{"name":"Apple","sold":1234}},{"_id":1,"value":{"name":"Amazon","sold":5678}}]我希望它最终成为[{"_id":0,"name":"Apple","sold":1234},{"_id":1,"name":"Amazon","sold":5678}]我想这可以用findAndMo

mongodb - 在 mongoDB 映射函数中发出完整文档而不将 (key,values) 对分配给 varchar

varmap=function(){varvalues={d_sno:this.d_sno,type:this.type};emit(this._id,values);};在上面的map函数中,我将(key,value)对分配给一个varchar并发出该varchar。我想在不将(key,value)对分配给varchar的情况下发出整个文档。 最佳答案 您可以像这样发出整个文档:varmap=function(){emit(this._id,this);};通过将整个文档作为一个值发出,发出的文档将如下所示:{"_id":Obje

c - 在迭代 bson 时访问 value.type

我正在尝试遵循libbsonAPI文档。但我好像弄错了什么。documentation声明你可以做:constbson_value_t*value;value=bson_iter_value(&iter);if(value.type==BSON_TYPE_INT32){printf("%d\n",value.value.v_int32);}但是当我尝试用它编译实际代码时,出现以下错误:example1.c:34:64:error:requestformember‘type’insomethingnotastructureorunion这里是实际的代码:#include#include#

arrays - MongoDB : find documents having 2 values in Array conforming to multiple criteria

假设,我们有文件:{_id:1,arr:[5,50]}{_id:2,arr:[11,53]}目标是找到数组中有2个值的文档,一个必须在范围(4,9)内,第二个在范围(45,55)内。在这种情况下,只有_id:1的文档应该返回。试过这个:db.Collection.find({arr:{$elemMatch:{$gte:4,$lte:9}}})-返回第一个文档db.Collection.find({arr:{$elemMatch:{$gte:45,$lte:55}}})-返回两者如何将这些标准组合在一起?db.Collection.find({arr:{$and:[{$elemMatch

node.js - Mongoose 通过 $set a value if NOT undefined 进行更新 (NodeJS)

检查未定义值的正确方法是什么?我想要做的是有一个PUT方法来更新那些不为空的字段。例如,如果我发送req.body.name='John'而没有发送req.body.job我希望我的请求只更改名称。部分代码:router.put('/:id',(req,res)=>{constquery={_id:req.params.id};constupdate={$set:{name:req.body.name,job:req.body.job}};User.findOneAndUpdate(query,update,(err,userUpdated)=>{if(err){console.log

javascript - "Cannot find global value ' Promise '"摩卡测试出错

以下内容与完整堆栈Node.js问题有关。它涉及Express、Mongoose和Mocha。我有一个Controller模块,它具有处理HTTP调用的功能。它基本上将Request和Response对象作为其参数。在其中,它将Form数据从Request对象中提取出来,并将数据存储在多个MongoDB实例中。为了完成多个数据存储,我们使用对Promise.all的调用。这是在异步函数中完成的。类似下面的内容asyncfunctionsaveData(data1:Data1Interface,data2:Data2Interface,res:Response){try{//Call3s

json - Mongoose 错误 : Cast to ObjectID failed for value on reading json for db seed

我有一个带有如下引用字段的模型方案:constUserSchema=newmongoose.Schema({//...uf:{type:mongoose.Schema.Types.ObjectId,ref:'UF',index:true},});我的测试数据库种子代码正在使用来自json文件的数据,如下所示:[{"_id":91283,"name":"Testuser","uf":124411923,"version":2}]在种子过程中,模型保存方法后,出现此错误:ValidationError:Uservalidationfailed:uf:CasttoObjectIDfailed