nodejs 里面 fs 模块提供了 readFile 和 readFileSync 同步和异步的 api
而 mysql 库里面的 query 都是同步的,而没有 querySync 之类的方法
数据库的读写和文件的 IO 有什么区别?是做不了还是只是保持异步的风格?
谢谢~
谢邀,node的那几个同步接口是为了方便开发者的,是原生提供的。
而其他几个数据库接口是第三方的模块,是其他的作者组织实现的。
一般情况下建议写异步,当然会有各种回调不优雅啥的,这时候就建议用原生提供的各种同步方法来优化代码,实现优雅。
比如: Generator / Promise / Async 等原生方案。
或者用co等封装过的主流异步处理方案
实际没有什么过程上的区别了,只是readFile是原生的API,官方提供了这种同步的在调用。而 query 是 node-mysql 模块提供的 api ,没给用户提供此类方法罢了。
readFile
query
实际你可以自己实现一个,正好 node v7+ 可以支持 async 和 await 了。类似这样的:
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) }
谢邀,node的那几个同步接口是为了方便开发者的,是原生提供的。
而其他几个数据库接口是第三方的模块,是其他的作者组织实现的。
一般情况下建议写异步,当然会有各种回调不优雅啥的,这时候就建议用原生提供的各种同步方法来优化代码,实现优雅。
比如: Generator / Promise / Async 等原生方案。
或者用co等封装过的主流异步处理方案
实际没有什么过程上的区别了,只是
readFile
是原生的API,官方提供了这种同步的在调用。而
query
是 node-mysql 模块提供的 api ,没给用户提供此类方法罢了。实际你可以自己实现一个,正好 node v7+ 可以支持
async
和await
了。类似这样的: