cari

Rumah  >  Soal Jawab  >  teks badan

node.js - [nodejs] 为什么文件的 api 有同步的,但是数据库操作几乎都是异步的?

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

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

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

谢谢~

巴扎黑巴扎黑2785 hari yang lalu469

membalas semua(2)saya akan balas

  • PHPz

    PHPz2017-04-17 15:30:14

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

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

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

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

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

    balas
    0
  • 迷茫

    迷茫2017-04-17 15:30:14

    实际没有什么过程上的区别了,只是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)
    }

    balas
    0
  • Batalbalas