我正在为node.js app使用node-mysql驱动程序。我没有为每个类似模型的模块反复设置mysql连接,而是这样做:
// DB.js
var Client = require('mysql').Client;
var DB_NAME = 'test_db';
var client = new Client();
client.user = 'user';
client.password = 'pass';
client.connect();
client.query('USE '+DB_NAME);
module.exports = client;
// in User.js
var db = require("./DB");
// and make calls like:
db.query(query, callback);
现在,我注意到DB.js仅使用DB连接初始化一次。因此,随后使用相同的client
对象...如何构建DB.js,以便在每次设置新的数据库连接时从模型中需要它?我知道这与使用new
有关,但我无法绕过它。
答案 0 :(得分:9)
module.exports = function() {
var client = new Client();
client.user = 'user';
client.password = 'pass';
client.connect();
client.query('USE '+DB_NAME);
return client;
}
var db = require("./DB")()
每次调用数据库时初始化一个新客户端。
您可以使用Object.defineProperty
使用自定义getter逻辑定义exports
,以便在需要时执行var db = require("./DB")
。