小编Jor*_*rza的帖子

AWS Athena MSCK REPAIR TABLE对于小型数据集来说需要太长时间

我遇到了amazon athena的问题,我有一个小桶(36430个对象,9.7 mb),有4级分区(my-bucket/p1 = ab/p2 = cd/p3 = ef/p4 = gh/file.csv)但是当我运行命令时

MSCK REPAIR TABLE db.table

我花了超过25分钟,我计划在Athena上放置结核病的数据,如果这个问题仍然存在,我将不会这样做

有谁知道为什么要花太长时间?

提前致谢

hive amazon-s3 amazon-web-services amazon-athena

7
推荐指数
2
解决办法
2658
查看次数

如何在猫鼬模型中处理 find 方法的回调结果

我使用 mongoose 作为 nodejs-mongodb 应用程序的 ODM。

是我的第一个 nodejs 应用程序,我来自非函数式编程背景。

查看猫鼬的文档,您可以找到:

Kitten.find(function (err, kittens) {
    if (err) return console.error(err);
    console.log(kittens);
});
Run Code Online (Sandbox Code Playgroud)

太好了,在这里我们将 find 函数作为我们模型(Kitten)的一部分,它实际上可以找到文档并在回调函数中将其检索为“kittens”,在这种情况下它使用 console.log() 。

但是我想知道这个函数式编程是如何用来将这个值分配给一个变量的(因为我在models文件夹的另一个文件中有这个,并且我用require导入了模块)

我发现了另一个关于类似要求 ObjectId 的问题,但是当您使用回调仅使用 console.log 打印答案时,它们提供了相同类型的答案,如果我们说实话,这没有用。

由于我来自非函数式编程背景,因此我期待以下内容:

var kitten = Kitten.find({name:'Silence'}); 
Run Code Online (Sandbox Code Playgroud)

据我所知,如果你在回调中分配一个新变量,变量的范围就在回调函数内,与返回变量相同,甚至在方法不起作用之前声明一个变量。

我确定我缺少某些东西。这个项目太大了,我认为他们不会忘记提供一种方法来做到这一点。我认为函数式编程中有一些我遗漏或我不知道的东西。

那么,如何才能做到这一点?

谢谢 !

编辑:我不知道为什么社区会说我的问题可能是How to return the response from an asynchronous call? 这个问题一般更面向 js ajax async 并且这个问题面向 ODM 框架以及如何处理它也可以通过承诺完成的结果,这是另一回事

callback mongodb node.js

2
推荐指数
1
解决办法
2692
查看次数