nodejs连接mysql数据库支持事物封装-mysql模块
nodejs连接mysql数据库支持事物封装-mysql模块
·
-- 安装模块
npm install mysql --连接数据库模块 ,基本封装看这里:http://blog.csdn.net/zzwwjjdj1/article/details/51991348
npm install async --异步流程控制模块 ,async模块介绍:http://blog.csdn.net/zzwwjjdj1/article/details/51857959
-- 封装代码
mysql.js
/*
nodejs连接mysql数据库支持事物封装
2016年7月26日14:47:06
QQ: 452076103 意外金喜
*/
var db = {};
var mysql = require('mysql');
var pool = mysql.createPool({
connectionLimit : 10,
host : 'localhost',
user : 'root',
password : '123456',
database : 'nodejs'
});
//获取连接
db.getConnection = function(callback){
pool.getConnection(function(err, connection) {
if (err) {
callback(null);
return;
}
callback(connection);
});
}
module.exports = db;
-- 测试-无错误
var db = require('./mysql.js');
var async = require('async');
db.getConnection(function(connection){
connection.beginTransaction(function(err) {
if (err) {
console.log(err);
return;
}
var task1 = function(callback){
connection.query(`insert into user (name) values('a')`, function(err, result) {
if (err) {
console.log(err);
callback(err,null);
return;
}
console.log('第一次插入成功!');
callback(null,result);
})
}
var task2 = function(callback){
connection.query(`insert into user (name) values('b')`, function(err, result) {
if (err) {
console.log(err);
callback(err,null);
return;
}
console.log('第二次插入成功!');
callback(null,result);
})
}
var task3 = function(callback){
connection.query(`insert into user (name) values('c')`, function(err, result) {
if (err) {
console.log(err);
callback(err,null);
return;
}
console.log('第三次插入成功!');
callback(null,result);
})
}
async.series([task1, task2, task3],function(err,result){
if (err) {
console.log(err);
//回滚
connection.rollback(function() {
console.log('出现错误,回滚!');
//释放资源
connection.release();
});
return;
}
//提交
connection.commit(function(err) {
if (err) {
console.log(err);
return;
}
console.log('成功,提交!');
//释放资源
connection.release();
});
})
});
})
运行结果:
数据库:
-- 发生错误
1.sql语句错误
比如把第三条sql语句user改为user1.
数据库还是之前插入的那3条数据,没有新增.
2.非sql语句错误
比如在async.series回调函数的第一行加入代码 : var err = 1;
人为添加错误
数据库依然没有新增数据,证明这个事物控制还是很靠谱的,之前写过nodejs连接sqlserver数据库支持事物的封装,
和sqlserver不同的地方是 :
sqlserver的事物在sql语句错误的时候会自动回滚,mysql的事物都需要手动回滚.
非sql错误的时候都一样,都必须手动回滚.
同样从begin方法开始,所有的程序错误都要手动处理,如果发生错误,而又没处理到,是不会回滚的.
更多推荐
已为社区贡献1条内容
所有评论(0)