gpt4 book ai didi

javascript - javascript/mongodb/mapreduce 中的全局变量

转载 作者:可可西里 更新时间:2023-11-01 10:44:12 24 4
gpt4 key购买 nike

我知道这个问题在互联网上被问过无数次,但我不知道这是怎么回事,我已经用头撞墙好几个小时了。

这个有效:

in myscript.js :

obj = 'hello';
var f = function() {
printjson('obj=' + obj);
}
f();

$ mongo myscript.js
obj=你好

这行不通:

date1 = "2013-09-03T00:00:00Z";
date2 = "2013-09-04T00:00:00Z";

var mapIntensities = function() {
emit(this.unit, this.intensity);
};

var reduceIntensities = function(unit, intensities) {
return {date: date1, "unit": unit, "intensity": Array.sum(intensities)};
};


db.units.mapReduce(mapIntensities, reduceIntensities, {out: "aggregate_intensities", query: {"DATE": {$gte: ISODate(date1), $lt: ISODate(date2)}}})

这是为什么呢?问题出现在 reduce() 函数中(如果只是在那里我用它工作的硬编码值替换 date1)

是不是mongodb做mapreduce的方式特有的? (如工作示例所示)

最佳答案

因为 date1 从未在 Map Reduce 本身中定义,所以它只在这里使用:

return {date: date1, "unit": unit, "intensity": Array.sum(intensities)};

然后您根本没有定义要输入到 Map Reduce 的实际调用中的变量。

Map Reduce 在 MongoDB 内的自包含 JavaScript(spidermonkey 或 v8)envo 中运行,而不是在 mongo 控制台中运行,正如我假设您在那里所做的那样。

您需要使用 scope 参数:http://docs.mongodb.org/manual/reference/command/mapReduce/#dbcmd.mapReduce发送 date1

关于javascript - javascript/mongodb/mapreduce 中的全局变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18658762/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com