mysqljs在koa2中的正确姿势
来源:SegmentFault
时间:2023-02-24 18:46:39 232浏览 收藏
本篇文章给大家分享《mysqljs在koa2中的正确姿势》,覆盖了数据库的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。
截止到今天,mysqljs在github上已经获取到了10000+star了,可以说是实实在在最流行的mysql驱动了,但是要把mysqljs应用到koa2中,似乎不太方便,koa2使用最新的语法async, await,而mysqljs,却还停留在callback阶段。
今天这篇文章就是要解决这个问题,非常简单。
1、实际开发中,我们肯定是使用连接池的形式,所以,我们选择了mysql.createPool这个方法:
var mysql = require('mysql'); var pool = mysql.createPool(...); pool.getConnection(function(err, connection) { // Use the connection connection.query('SELECT something FROM sometable', function (error, results, fields) { // And done with the connection. connection.release(); // Handle error after the release. if (error) throw error; // Don't use the connection here, it has been returned to the pool. }); });
2、使用Promise,对上面的方法稍加改造即可:
var mysql = require('mysql'); var pool = mysql.createPool(...); const q = function (sql, values) { return new Promise((resolve, reject) => { pool.getConnection((err, conn) => { if (err) return reject(err) conn.query(sql, values, (err, rows) => { if (err) reject(err) else resolve(rows) conn.release() }) }) }) }
经过以上封装,一个查询用户信息的操作就可以这样优雅的完成了:
async function getUserInfoById(id) { let userInfo = await q('select * from user where id=?', [id]) console.log(userInfo) }
3、受tornado的一个mysql操作库torndb的启发,可以这样做一个完整的封装:
const mysql = require('mysql') const defautConfig = { host: 'localhost', user: 'root', password: '', database: 'test', connectionLimit: 20 } const AsyncMysqljs = function(config=defautConfig){ const pool = mysql.createPool(config) const q = function (sql, values) { return new Promise((resolve, reject) => { pool.getConnection((err, conn) => { if (err) return reject(err) conn.query(sql, values, (err, rows) => { if (err) reject(err) else resolve(rows) conn.release() }) }) }) } /* 从数据库中查询一条数据,返回值是对象,而非数组 最好在sql语句中加一个唯一的限制条件 */ const get = (sql, values) => { try { return q(sql, values).then(rows => { if (rows.length >= 1) { return rows[0] } }) } catch (err) { return new Promise((resolve, reject) => { reject(err) }) } } return {query: q, delete: q, update: q, insert: q, execute: q, get} } module.exports = AsyncMysqljs
具体代码请查看我的github项目asyncmysqljs,欢迎给建议或者star。
文中关于mysql的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《mysqljs在koa2中的正确姿势》文章吧,也可关注golang学习网公众号了解相关技术文章。
声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
最新阅读
更多>
-
485 收藏
-
113 收藏
-
293 收藏
-
365 收藏
-
247 收藏
-
188 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习