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 提示‘xxx’ 不是内部或外部命令解决方法
Nov 20 NodeJs
NodeJS学习笔记之Connect中间件模块(二)
Jan 27 NodeJs
nodeJs爬虫获取数据简单实现代码
Mar 29 NodeJs
浅谈Nodejs应用主文件index.js
Aug 28 NodeJs
使用nodejs下载风景壁纸
Feb 05 NodeJs
nodejs个人博客开发第一步 准备工作
Apr 12 NodeJs
Nodejs进阶:express+session实现简易登录身份认证
Apr 24 NodeJs
NodeJS、NPM安装配置步骤(windows版本) 以及环境变量详解
May 13 NodeJs
nodejs之get/post请求的几种方式小结
Jul 26 NodeJs
NodeJS收发GET和POST请求的示例代码
Aug 25 NodeJs
Nodejs把接收图片base64格式保存为文件存储到服务器上
Sep 26 NodeJs
nodejs中方法和模块用法示例
Dec 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
Gregarius中文日期格式问题解决办法
2008/04/22 PHP
PHP 压缩文件夹的类代码
2009/11/05 PHP
PHP同时连接多个mysql数据库示例代码
2014/03/17 PHP
laravel 实现用户登录注销并限制功能
2019/10/24 PHP
javascript在一段文字中的光标处插入其他文字
2007/08/26 Javascript
50个比较实用jQuery代码段
2011/09/18 Javascript
JavaScript实现16进制颜色值转RGB的方法
2015/02/09 Javascript
jquery实现简单Tab切换菜单效果
2020/07/17 Javascript
你知道setTimeout是如何运行的吗?
2016/08/16 Javascript
PHP+jquery+ajax实现分页
2016/12/09 Javascript
利用js定义一个导航条菜单
2017/03/14 Javascript
如何使用angularJs
2017/05/08 Javascript
bootstrap table插件的分页与checkbox使用详解
2017/07/23 Javascript
详解微信小程序之提高应用速度小技巧
2020/01/07 Javascript
微信小程序getLocation 需要在app.json中声明permission字段
2020/03/03 Javascript
解决vue单页面应用进入页面加载所有 js 的问题
2020/08/12 Javascript
JavaScript常用工具函数库汇总
2020/09/17 Javascript
[06:30]DOTA2英雄梦之声_第15期_死亡先知
2014/06/21 DOTA
跟老齐学Python之坑爹的字符编码
2014/09/28 Python
基于Python闭包及其作用域详解
2017/08/28 Python
Python实现可设置持续运行时间、线程数及时间间隔的多线程异步post请求功能
2018/01/11 Python
Python批量提取PDF文件中文本的脚本
2018/03/14 Python
对pandas通过索引提取dataframe的行方法详解
2019/02/01 Python
说说如何遍历Python列表的方法示例
2019/02/11 Python
详解python持久化文件读写
2019/04/06 Python
在Python中表示一个对象的方法
2019/06/25 Python
关于TensorFlow新旧版本函数接口变化详解
2020/02/10 Python
python实现将列表中各个值快速赋值给多个变量
2020/04/02 Python
HTML5仿手机微信聊天界面
2016/03/18 HTML / CSS
H5 meta小结(前端必看篇)
2016/08/24 HTML / CSS
英国领先的游戏零售商:GAME
2019/09/24 全球购物
爱情寄语大全
2014/04/09 职场文书
工作检讨书500字
2014/10/19 职场文书
导游词之台湾阿里山
2019/10/23 职场文书
详解Python函数print用法
2021/06/18 Python
使用 CSS 构建强大且酷炫的粒子动画效果
2022/08/14 HTML / CSS