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中exports与module.exports的区别详细介绍
Jan 14 NodeJs
nodejs 实现模拟form表单上传文件
Jul 14 NodeJs
Nodejs学习笔记之NET模块
Jan 13 NodeJs
nodejs实现获取当前url地址及url各种参数值
Jun 25 NodeJs
基于nodejs+express(4.x+)实现文件上传功能
Nov 23 NodeJs
Nodejs Stream 数据流使用手册
Apr 17 NodeJs
详解使用vscode+es6写nodejs服务端调试配置
Sep 21 NodeJs
nodejs基于WS模块实现WebSocket聊天功能的方法
Jan 12 NodeJs
Nodejs中的require函数的具体使用方法
Apr 02 NodeJs
Nodejs监控事件循环异常示例详解
Sep 22 NodeJs
nodejs语言实现验证码生成功能的示例代码
Oct 13 NodeJs
如何利用nodejs实现命令行游戏
Nov 24 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基础教程(php入门基础教程)一些code代码
2013/01/06 PHP
php实现监听事件
2013/11/06 PHP
php中explode函数用法分析
2014/11/15 PHP
php页面,mysql数据库转utf-8乱码,utf-8编码问题总结
2015/08/27 PHP
百度地图经纬度转换到腾讯地图/Google 对应的经纬度
2015/08/28 PHP
实例讲解PHP设计模式编程中的简单工厂模式
2016/02/29 PHP
php+ajax实现带进度条的上传图片功能【附demo源码下载】
2016/09/14 PHP
PHP命名空间与自动加载类详解
2018/09/04 PHP
关于恒等于(===)和非恒等于(!==)
2007/08/20 Javascript
JavaScript 加号(+)运算符号
2009/12/06 Javascript
javascript单引号和双引号的区别和处理
2014/05/14 Javascript
推荐5 个常用的JavaScript调试技巧
2015/01/08 Javascript
JavaScript 匿名函数和闭包介绍
2015/04/13 Javascript
jQuery入门之层次选择器实例简析
2015/12/11 Javascript
Bootstrap轮播插件使用代码
2016/10/11 Javascript
Bootstrap table使用方法详细介绍
2016/12/09 Javascript
jquery滚动条插件slimScroll使用方法
2017/02/09 Javascript
webpack打包react项目的实现方法
2018/06/21 Javascript
jQuery实现颜色打字机的完整代码
2020/03/19 jQuery
Vue插件之滑动验证码用法详解
2020/04/05 Javascript
[05:08]2014DOTA2国际邀请赛 Hao专访复仇的胜利很爽
2014/07/15 DOTA
Python编程入门的一些基本知识
2015/05/13 Python
基于Python实现通过微信搜索功能查看谁把你删除了
2016/01/27 Python
python对json的相关操作实例详解
2017/01/04 Python
python实现的MySQL增删改查操作实例小结
2018/12/19 Python
Python3.5面向对象编程图文与实例详解
2019/04/24 Python
使用pyqt 实现重复打开多个相同界面
2019/12/13 Python
python支持多线程的爬虫实例
2019/12/21 Python
python每5分钟从kafka中提取数据的例子
2019/12/23 Python
python同义词替换的实现(jieba分词)
2020/01/21 Python
使用python 计算百分位数实现数据分箱代码
2020/03/03 Python
司机的工作范围及职责
2013/11/13 职场文书
房地产促销活动方案
2014/03/01 职场文书
世博会口号
2014/06/20 职场文书
2015年乡镇工会工作总结
2015/05/19 职场文书
python plt.plot bar 如何设置绘图尺寸大小
2021/06/01 Python