求解mongodb mapreduce 遍历values的问题。
ringa_lee
ringa_lee 2017-04-28 09:06:06
0
1
551

在mongodb mapreduce的reduce函数中,参数values是一个数组,可以用values.forEach进行遍历。

function(key, values){ //values 是一个数组 values.forEach(function(val){ //val即为数组里的元素 }); }

但是values比较大时,values会被会被拆分存储,在原本Reduce函数中的forEach只遍历了第一层的数据,无法遍历所有的元素。那请问如何遍历values里的所有元素?

ringa_lee
ringa_lee

ringa_lee

membalas semua (1)
伊谢尔伦

mapreduce 中还有一个参数 scope ,可以放置 js 函数中所用到的变量,你可以将 value 数据暂存到其中,这样就能跨越单个 reduce 函数获得数据了。不过既然是 values 被拆分了,就说明 values 内的数据量较大,如果只是强行把所有的 values 组合起来,并不是一个好的办法,内存会吃紧。最好还是优化 map 函数,较少 values 数据量。

    Muat turun terkini
    Lagi>
    kesan web
    Kod sumber laman web
    Bahan laman web
    Templat hujung hadapan
    Tentang kita Penafian Sitemap
    Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!