我是事件/回调风格编程和 NodeJS 的新手。我正在尝试实现一个小的 http 服务器,它使用 node-mysql module提供 ddbb 数据。
我的问题来自查询结构。由于经常有查询需要运行先前查询的结果,因此我无法同时(异步)运行所有这些查询,我不得不等待一些结果。
我的第一种方法是同时运行所有非依赖查询,然后循环,直到所有查询都设置了一个标志,说我已经完成,这样我就可以继续使用依赖(同步)查询,但我没有知道这是否是正确的方法。
像这样的东西:
function x(){
var result_for_asynch_query_1 = null
var result_for_asynch_query_2 = null
mainLoop(){
// call non-dependant query 1
// call non-dependant query 2
// loop until vars are != null
// continue with queries that require data from the first ones
}
}
//for each browser request
httpServer{
call_to_x();
}.listen();
这样我可以在最终结果中节省一些时间,因为我不会以串行方式等待所有响应,而是等待最长的响应。
有没有一种通用的方法来做到这一点?我没有遵循任何设计模式?