NodeJs使用Mysql模块实现事务处理实例


Posted in NodeJs onMay 31, 2017

依赖模块:

1. mysql:https://github.com/felixge/node-mysql

npm install mysql --save

2. async:https://github.com/caolan/async

npm install async --save

(ps: async模块可换成其它Promise模块如bluebird、q等) 

因为Node.js的mysql模块本身对于事务的封装过于简单,而且直接使用会有很严重callback hell,故我们封装了两个方法,一个用来初始化sql & params,一个用来执行事务。

初始化sql & params:

function _getNewSqlParamEntity(sql, params, callback) {
  if (callback) {
    return callback(null, {
      sql: sql,
      params: params
    });
  }
  return {
    sql: sql,
    params: params
  };
}

如果你要执行多条sql语句,则需要:

var sqlParamsEntity = [];
var sql1 = "insert table set a=?, b=? where 1=1";
var param1 = {a:1, b:2};
sqlParamsEntity.push(_getNewSqlParamEntity(sql1, param1));

var sql2 = "update ...";
sqlParamsEntity.push(_getNewSqlParamEntity(sql1, []));

//...更多要事务执行的sql

然后我在我自己的dbHelper.js里封装了execTrans的函数,用来执行事务

var mysql = require('mysql');
var async = require("async");

module.exports = {
  execTrans: execTrans,
}

var pool = mysql.createPool({
  host: "mysql host",
  user: "mysql login user",
  password: "mysql login pwd",
  database: "target db name",
  connectionLimit: 10,
  port: "mysql db port",
  waitForConnections: false
});

function execTrans(sqlparamsEntities, callback) {
  pool.getConnection(function (err, connection) {
    if (err) {
      return callback(err, null);
    }
    connection.beginTransaction(function (err) {
      if (err) {
        return callback(err, null);
      }
      console.log("开始执行transaction,共执行" + sqlparamsEntities.length + "条数据");
      var funcAry = [];
      sqlparamsEntities.forEach(function (sql_param) {
        var temp = function (cb) {
          var sql = sql_param.sql;
          var param = sql_param.params;
          connection.query(sql, param, function (tErr, rows, fields) {
            if (tErr) {
              connection.rollback(function () {
                console.log("事务失败," + sql_param + ",ERROR:" + tErr);
                throw tErr;
              });
            } else {
              return cb(null, 'ok');
            }
          })
        };
        funcAry.push(temp);
      });

      async.series(funcAry, function (err, result) {
        console.log("transaction error: " + err);
        if (err) {
          connection.rollback(function (err) {
            console.log("transaction error: " + err);
            connection.release();
            return callback(err, null);
          });
        } else {
          connection.commit(function (err, info) {
            console.log("transaction info: " + JSON.stringify(info));
            if (err) {
              console.log("执行事务失败," + err);
              connection.rollback(function (err) {
                console.log("transaction error: " + err);
                connection.release();
                return callback(err, null);
              });
            } else {
              connection.release();
              return callback(null, info);
            }
          })
        }
      })
    });
  });
}

这样就可以执行事务了:

execTrans(sqlParamsEntity, function(err, info){
if(err){
  console.error("事务执行失败");
}else{
  console.log("done.");
}
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
NodeJS学习笔记之Connect中间件模块(二)
Jan 27 NodeJs
nodejs创建web服务器之hello world程序
Aug 20 NodeJs
用NodeJS实现批量查询地理位置的经纬度接口
Aug 16 NodeJs
nodejs+express实现文件上传下载管理网站
Mar 15 NodeJs
NodeJs测试框架Mocha的安装与使用
Mar 28 NodeJs
详解nodejs爬虫程序解决gbk等中文编码问题
Apr 06 NodeJs
初识NodeJS服务端开发入门(Express+MySQL)
Apr 07 NodeJs
详解nodejs模板引擎制作
Jun 14 NodeJs
NodeJS实现视频转码的示例代码
Nov 18 NodeJs
nodejs结合Socket.IO实现的即时通讯功能详解
Jan 12 NodeJs
nodeJs实现基于连接池连接mysql的方法示例
Feb 10 NodeJs
nodejs微信开发之自动回复的实现
Mar 17 NodeJs
基于nodejs 的多页面爬虫实例代码
May 31 #NodeJs
详解nodeJS之路径PATH模块
May 31 #NodeJs
NodeJS实现微信公众号关注后自动回复功能
May 31 #NodeJs
nodejs操作mysql实现增删改查的实例
May 28 #NodeJs
详解nodejs微信jssdk后端接口
May 25 #NodeJs
mac下的nodejs环境安装的步骤
May 24 #NodeJs
Nodejs搭建wss服务器教程
May 24 #NodeJs
You might like
php与paypal整合方法
2010/11/28 PHP
FireFox浏览器使用Javascript上传大文件
2013/10/30 PHP
PHP实现递归复制整个文件夹的类实例
2015/08/03 PHP
javascript parseInt 函数分析(转)
2009/03/21 Javascript
javascript中interval与setTimeOut的区别示例介绍
2014/03/14 Javascript
点击表单提交时出现jQuery没有权限的解决方法
2014/07/23 Javascript
jQuery判断数组是否包含了指定的元素
2015/03/10 Javascript
基于jQuery和CSS3制作数字时钟附源码下载(jquery篇)
2015/11/24 Javascript
深入分析javascript中的错误处理机制
2016/07/17 Javascript
微信小程序 Storage API实例详解
2016/10/02 Javascript
mac下的nodejs环境安装的步骤
2017/05/24 NodeJs
Nodejs回调加超时限制两种实现方法
2017/06/09 NodeJs
React diff算法的实现示例
2018/04/20 Javascript
JS实现统计字符串中字符出现个数及最大个数功能示例
2018/06/04 Javascript
解决vue数组中对象属性变化页面不渲染问题
2018/08/09 Javascript
vue中多路由表头吸顶实现的几种布局方式
2019/04/12 Javascript
初步理解Python进程的信号通讯
2015/04/09 Python
python中pylint使用方法(pylint代码检查)
2018/04/06 Python
django rest framework 实现用户登录认证详解
2019/07/29 Python
pandas DataFrame的修改方法(值、列、索引)
2019/08/02 Python
关于pymysql模块的使用以及代码详解
2019/09/01 Python
基于Python实现拆分和合并GIF动态图
2019/10/22 Python
Numpy中的数组搜索中np.where方法详细介绍
2021/01/08 Python
程序设计HTML5 Canvas API
2013/04/08 HTML / CSS
Monki官网:斯堪的纳维亚的独立时尚品牌
2020/11/09 全球购物
某公司面试题
2012/03/05 面试题
百度JavaScript笔试题
2015/01/15 面试题
如何开发安全的AJAX应用
2014/03/26 面试题
实习鉴定评语
2014/01/19 职场文书
员工试用期考核自我鉴定
2014/04/13 职场文书
财务工作疏忽检讨书
2014/09/11 职场文书
2015年办公室主任工作总结
2015/04/09 职场文书
朋友聚会开场白
2015/06/01 职场文书
家长反馈意见及建议
2015/06/03 职场文书
CSS3实现的3D隧道效果
2021/04/27 HTML / CSS
python基础之类方法和静态方法
2021/10/24 Python