zoukankan      html  css  js  c++  java
  • NodeJs使用Mysql模块实现事务处理

    依赖模块:

    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.");
    }
    })
    复制代码

    仓促写给项目用,大神也可以帮我改进这个封装。

    很多年以后,我有个名字叫西毒……
  • 相关阅读:
    js、css等文件引入空白问题
    Vue 组件 data为什么是函数
    安装Node,创建vue项目,运行及打包
    JQuery移除事件
    百度地图定位
    移动端导航过多,点击导航左右滚动回弹
    移动端开发模板
    移动端左右滑动导航
    使用‘圣杯布局’、‘双飞翼布局’来解释自适应的三栏水平布局
    css实现三角箭头
  • 原文地址:https://www.cnblogs.com/xiami2046/p/12755953.html
Copyright © 2011-2022 走看看