博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用node-mysql中的连接池
阅读量:7082 次
发布时间:2019-06-28

本文共 2258 字,大约阅读时间需要 7 分钟。

  hot3.png

根据原来generic-pool的例子修改过来的,这样可以少一个依赖了,哈哈 mysql-pool.js

var mysql       = require('mysql');var mysqlConfig = require('../config/mysql');var env = process.env.NODE_ENV || 'development';if(mysqlConfig[env]) {  mysqlConfig = mysqlConfig[env];}exports.createMysqlPool= module.exports.createMysqlPool = function(){  return mysql.createPool({        host: mysqlConfig.host,        user: mysqlConfig.user,        password: mysqlConfig.password,        database: mysqlConfig.database  });}

创建一个简单的客户端链接帮助类 mysqlclient

// mysql CRUDvar sqlclient = module.exports;var _pool = null;var NND = {};/* * Innit sql connection pool * @param {Object} app The app for the server. */NND.init = function(){  if(!_pool)    _pool = require('./mysql-pool').createMysqlPool();};/** * Excute sql statement * @param {String} sql Statement The sql need to excute. * @param {Object} args The args for the sql. * @param {fuction} callback Callback function. *  */NND.query = function(sql, args, callback){  _pool.getConnection(function(err, client) {    if (!!err) {      console.error('[sqlqueryErr] '+err.stack);      return;    }    client.query(sql, args, function(err, res) {      _pool.releaseConnection(client);      callback.apply(null, [err, res]);    });  });};/** * Close connection pool. */NND.shutdown = function(){  _pool.end();};/** * init database */sqlclient.init = function() {  if (!!_pool){    return sqlclient;  } else {    NND.init();    sqlclient.insert = NND.query;    sqlclient.update = NND.query;    //sqlclient.delete = NND.query;    sqlclient.query = NND.query;    return sqlclient;  }};/** * shutdown database */sqlclient.shutdown = function() {  NND.shutdown();};

实际调用类

var utils = require('../lib/utils');var mysqlClient = require('./mysqlcliet').init();var orgdao = module.exports;orgdao.queryOrgByPId = function (pid, cb){    var sql = 'YOUR SQL';    var args = [pid];    mysqlClient.query(sql,args,function(err, res){        if(err !== null){            utils.invokeCallback(cb, err.message, null);        }         else {            if (!!res) {                utils.invokeCallback(cb, null, res);            }            else{                utils.invokeCallback(cb, null, null);            }        }    });};

转载于:https://my.oschina.net/redhu/blog/122255

你可能感兴趣的文章
我的友情链接
查看>>
iOS 图片合并 及截图
查看>>
easyui datagrid load 方法键不能为变量的解决
查看>>
分治的一次简单实践
查看>>
博为峰Java面试题-JavaSE I/O之File写入读出
查看>>
USER username (Login failed): Invalid shell: '/bin/false'
查看>>
我的友情链接
查看>>
Linux下整合Apache和Tomcat
查看>>
桌面图标右键选择发送到就会出现卡住假死
查看>>
关于旅行的文章..............搜集
查看>>
golang接口的使用(练习一)
查看>>
linux笔记之DNS服务配置(一)
查看>>
我的友情链接
查看>>
Nginx HTTP负载均衡和反向代理配置
查看>>
Redis 安装(一)
查看>>
nil, Nil, NULL 的区别
查看>>
lsof -i -n -P
查看>>
RocketMQ高并发读写
查看>>
Kali linux上运行quasibot时主页不显示内容的问题
查看>>
CentOS 5.5下搭建Mysql+DRBD+Heartbeat
查看>>