当前位置: 首页 > 知识库问答 >
问题:

mongo mapreduce中的断言异常

漆雕安晏
2023-03-14

我有一个存储搜索查询日志的集合。它的两个主要属性是user_id和search_query。对于已注销的用户,user_id为null。我正在尝试运行mapreduce作业以找出每个用户的计数和术语。

var map = function(){
  if(this.user_id !== null){
    emit(this.user_id, this.search_query);
  }
}
var reduce = function(id, queries){
  return Array.sum(queries + ",");
}
db.searchhistories.mapReduce(map,
  reduce,
  {
    query: { "time" : {
                        $gte :  ISODate("2013-10-26T14:40:00.000Z"),
                        $lt  :  ISODate("2013-10-26T14:45:00.000Z")
                       }
           },
    out : "mr2"
  }
)
Wed Nov 27 06:00:07 uncaught exception: map reduce failed:{
        "errmsg" : "exception: assertion src/mongo/db/commands/mr.cpp:760",
        "code" : 0,
        "ok" : 0
}
> db.searchhistories.find()
{ "_id" : ObjectId("5247a9e03815ef4a2a005d8b"), "results" : 82883, "response_time" : 0.86, "time" : ISODate("2013-09-29T04:17:36.768Z"), "type" : 0, "user_id" : null, "search_query" : "awareness campaign" }
{ "_id" : ObjectId("5247a9e0606c791838005cba"), "results" : 39545, "response_time" : 0.369, "time" : ISODate("2013-09-29T04:17:36.794Z"), "type" : 0, "user_id" : 34225174, "search_query" : "eficaz eficiencia efectividad" }

共有1个答案

戈睿识
2023-03-14

看着文件,我可以看出这在奴隶身上是不可能的。但它在主人身上会很好地工作。如果您还想使用从属,那么您必须使用以下语法。

db.searchhistories.mapReduce(map, 
 reduce,
  {
    query: { "time" : {
                    $gte :  ISODate("2013-10-26T14:40:00.000Z"),
                    $lt  :  ISODate("2013-10-26T14:45:00.000Z")
                   }
       },
    out : { inline : 1 }
 }
)

**使用内联函数时,确保输出文档大小不超过16MB限制。

 类似资料:
  • 问题内容: Java异常处理和使用条件之间有什么区别? 众所周知,Assert有两种类型。但是什么时候应该使用关键字? 问题答案: 将断言用于代码中的内部逻辑检查,并使用常规异常来处理即时代码无法控制的错误情况。 不要忘记可以打开和关闭断言-如果您关心参数验证之类的事情,则应该使用异常来明确声明。(但是,您可以选择使用断言在 私有 方法上执行参数验证,原因是此时的违反是由于内部错误而不是外部错误引

  • 问题内容: 我抛出了异常而不是显示失败,这是我做错了,还是我应该在线程内没有断言? 堆栈跟踪 问题答案: JUnit框架仅捕获运行测试的主线程中的断言错误。它不知道新的派生线程中的异常。为了正确执行此操作,您应该将线程的终止状态传达给主线程。您应该正确同步线程,并使用某种共享变量来指示嵌套线程的结果。 编辑: 这是可以提供帮助的通用解决方案: 您应该在构造函数中将其传递给runnable,然后只需

  • 由于 Vue 进行异步更新 DOM的情况,一些依赖 DOM 更新结果的断言必须在Vue.nextTick回调中进行: // 在状态更新后检查生成的 HTML it('updates the rendered message when vm.message updates', done => { const vm = new Vue(MyComponent).$mount() vm.mes

  • 我想测试一个特定的方法是否可以毫无例外地处理一组字符串。因此,我想使用AssertJ的软断言,比如: 不幸的是,我必须坚持使用AssertJ 1。x分别是Java 6,所以我不能利用这一点: 有没有办法用AssertJ(或JUnit)做到这一点?

  • 版本: 我得到以下错误:

  • 问题内容: 今天,我看到了一个带有Java断言而不是JUnit断言的JUnit测试用例-相对于另一个而言,优先选择一个优点还是缺点? 问题答案: 在JUnit4中,JUnit断言引发的异常(实际上是Error)与java 关键字(AssertionError)引发的错误相同,因此它与堆栈跟踪完全相同,除了您无法分辨出其区别。 话虽这么说,断言必须在JVM中使用特殊标志运行,导致许多测试似乎通过了,