node.js - [nodejs] 为什么文件的 api 有同步的,但是数据库操作几乎都是异步的?
巴扎黑
巴扎黑 2017-04-17 15:28:14
0
2
462

nodejs 里面 fs 模块提供了 readFile 和 readFileSync 同步和异步的 api

而 mysql 库里面的 query 都是同步的,而没有 querySync 之类的方法

数据库的读写和文件的 IO 有什么区别?是做不了还是只是保持异步的风格?

谢谢~

巴扎黑
巴扎黑

membalas semua(2)
PHPzhong

谢邀,node的那几个同步接口是为了方便开发者的,是原生提供的。

而其他几个数据库接口是第三方的模块,是其他的作者组织实现的。

一般情况下建议写异步,当然会有各种回调不优雅啥的,这时候就建议用原生提供的各种同步方法来优化代码,实现优雅。

比如: Generator / Promise / Async 等原生方案。

或者用co等封装过的主流异步处理方案

迷茫

实际没有什么过程上的区别了,只是readFile是原生的API,官方提供了这种同步的在调用。
query 是 node-mysql 模块提供的 api ,没给用户提供此类方法罢了。

实际你可以自己实现一个,正好 node v7+ 可以支持 asyncawait 了。
类似这样的:

querySync(sql, data) {
    return new Promise((resolve, reject) => {
        connection.query(sql, data, (err, result) => {
            if (err) {
                reject(err);
                return;
            }
            resolve(result);
        });
    });
}

async getData(sql, data) {
    const data = await querySync(sql, data)
}
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan