1.mysql 及 promise-mysql
nodejs 连接 mysql 有成熟的npm包 mysql ,如果需要promise,建议使用 promise-mysql;
在实际开发中,单独的connection 并不能满足业务需要,需要使用连接池进行连接的建立及释放,promise-mysql 建立连接池非常简单:
1 const config ={2 host:‘xxxxxx‘, //ip也行域名也行
3 user:‘root‘,4 password:‘123456‘,5 connectionLimit:30,6 database:‘movie‘, //database
7 port:‘8306‘
8 };9 //建立连接池
10 const pool =mysql.createPool(config);11 //使用pool.query 快速连接执行sql
12 pool.query(‘xxxx‘);13
14 //用using/dispsoer 模式构建自动释放资源的连接
15 functiongetSqlConnection(){16 return pool.getConnection().disposer((c)=>{17 pool.releaseConnection(c);18 });19 }20 //需要使用bluebird 封装具有dispsoer功能的promise对象
21 functionquery(sql){22 return Promise.using(getSqlConnection(),(con)=>{23 return sql?con.query(sql):con;24 })25 }
经过对mysql 连接的promise封装,我们可以使用async/await方式进行愉快的编程
2.通过p