對(duì)于NodeJs如何使用Mysql模塊完成事務(wù)處理案例
發(fā)表時(shí)間:2023-08-26 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]本篇文章主要介紹了NodeJs使用Mysql模塊實(shí)現(xiàn)事務(wù)處理 ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧依賴模塊:1. mysqlnpm install mysql --save2. asyncnpm install async --save(ps: async模...
本篇文章主要介紹了Node
Js使用Mysql模塊實(shí)現(xiàn)事務(wù)處理 ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
依賴模塊:
1. mysql
npm install mysql --save
2. async
npm install async --save
(ps: async模塊可換成其它Promise模塊如bluebird、q等)
因?yàn)?a target="_blank">Node.js的mysql模塊本身對(duì)于事務(wù)的封裝過于簡(jiǎn)單,而且直接使用會(huì)有很嚴(yán)重callback hell,故我們封裝了兩個(gè)方法,一個(gè)用來初始化sql & params,一個(gè)用來執(zhí)行事務(wù)。
初始化sql & params:
function _getNewSqlParamEntity(sql, params, callback) {
if (callback) {
return callback(null, {
sql: sql,
params: params
});
}
return {
sql: sql,
params: params
};
}
如果你要執(zhí)行多條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, []));
//...更多要事務(wù)執(zhí)行的sql
然后我在我自己的dbHelper.js里封裝了execTrans的函數(shù),用來執(zhí)行事務(wù)
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("開始執(zhí)行transaction,共執(zhí)行" + sqlparamsEntities.length + "條數(shù)據(jù)");
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("事務(wù)失敗," + 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("執(zhí)行事務(wù)失敗," + err);
connection.rollback(function (err) {
console.log("transaction error: " + err);
connection.release();
return callback(err, null);
});
} else {
connection.release();
return callback(null, info);
}
})
}
})
});
});
}
這樣就可以執(zhí)行事務(wù)了:
execTrans(sqlParamsEntity, function(err, info){
if(err){
console.error("事務(wù)執(zhí)行失敗");
}else{
console.log("done.");
}
})
以上就是關(guān)于NodeJs如何使用Mysql模塊實(shí)現(xiàn)事務(wù)處理實(shí)例的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!
學(xué)習(xí)教程快速掌握從入門到精通的SQL知識(shí)。