nodejs连接mysql数据库支持事物封装-mysql模块
来源:互联网 发布:制作音乐的软件 编辑:程序博客网 时间:2024/05/16 15:15
-- 安装模块
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:06QQ: 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方法开始,所有的程序错误都要手动处理,如果发生错误,而又没处理到,是不会回滚的.
0 0
- nodejs连接mysql数据库支持事物封装-mysql模块
- nodejs连接sqlserver数据库支持事物封装-mssql模块
- nodejs连接sqlserver数据库支持事物封装-mssql模块
- nodejs连接mysql数据库简单封装-mysql模块
- NodeJs连接Mysql数据库
- nodejs 连接mysql数据库操练
- nodejs封装的mysql链接数据库
- nodejs连接池连接mysql数据库
- 封装jsp连接mysql数据库
- Mysql连接数据库封装类
- Mysql连接数据库封装类
- nodejs连接sqlserver数据库简单封装-mssql模块
- nodejs连接redis数据库简单封装-redis模块
- mysql数据库事物
- MySQL数据库操作类,支持严格模式的事物处理
- NodeJS连接自定义地址的Mysql数据库
- nodejs连接mysql数据库及基本认识
- 自己封装的Mysql数据库操作模块
- 关于 Arraylist和HashSet中元素比较的问题所引发的思考
- PHP进阶(五)——文件操作
- docker容器资源配额控制
- JAVA打印文件目录
- Java8使用lambda表达式写的一个List,Set,Map遍历工具类
- nodejs连接mysql数据库支持事物封装-mysql模块
- HDU5573 Binary Tree(构造)
- 下载zip文件并解压
- rails中的多态表关联
- 01-swift微博初始化项目
- Java POI读取Excel 2003/2007/2010例子
- 在页面中嵌入Applet使用opencv调用摄像头,并显示实时摄像头内容
- Android中最常问到的面试题
- 这里有一份面经请查收(三)