node mysql promise_nodejs 优雅的连接 mysql

本文介绍了如何在 Node.js 中使用 promise-mysql 创建和管理 MySQL 连接池,以及如何优雅地执行 SQL 查询和事务操作。通过 disposer 模式确保连接在使用后自动释放,简化了代码并提高了代码的可读性。示例代码展示了如何创建连接池、使用 `pool.query` 执行 SQL,以及如何在 async/await 语法下处理事务。
摘要由CSDN通过智能技术生成

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.通过promise-mysql执行事务

通过connection对象的beginTransaction、commit 及 rollback 即可实现

1 async functionexecAffairs(){2 console.log(‘begin execAffairs‘);3 //写事务

4 const conn =await query();5 await conn.beginTransaction(); //begin;

6 try{7 await conn.query(‘select * from movie_detail where m_id=242167 for update‘);8 await conn.query(‘update movie_detail set m_record=7.5 where m_id=242167‘);9 await conn.commit();//commit

10 console.log(‘commit 完毕‘);11 } catch(e){12 console.log(‘事务出错‘,e);13 await conn.rollback();14 }15 /******16 // 无需release17 finally{18 conn.release();19 }20 */

21 }

由于本示例使用了promise-mysql 的disposer 模式,所以无需额外处理 连接的 release

相关代码请见:https://github.com/JhoneLee/nodeScheduleMySql

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值