Rumah > Soal Jawab > teks badan
nodejs 里面 fs 模块提供了 readFile 和 readFileSync 同步和异步的 api
而 mysql 库里面的 query 都是同步的,而没有 querySync 之类的方法
数据库的读写和文件的 IO 有什么区别?是做不了还是只是保持异步的风格?
谢谢~
PHPz2017-04-17 15:30:14
谢邀,node的那几个同步接口是为了方便开发者的,是原生提供的。
而其他几个数据库接口是第三方的模块,是其他的作者组织实现的。
一般情况下建议写异步,当然会有各种回调不优雅啥的,这时候就建议用原生提供的各种同步方法来优化代码,实现优雅。
比如: Generator / Promise / Async 等原生方案。
或者用co等封装过的主流异步处理方案
迷茫2017-04-17 15:30:14
实际没有什么过程上的区别了,只是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)
}