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

浏览:30日期:2022-09-30

问题描述

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

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

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

谢谢~

问题解答

回答1:

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

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

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

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

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

回答2:

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

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

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)}

相关文章: