我正在尝试使用db-mysql库从node.js连接到MySQL数据库。使用示例代码,一切都很好,但现在我正在尝试编写一个简单的ORM。
这是我的代码:
require.paths.unshift('/usr/lib/node_modules'); // default require.paths doesn't include this
function Model() {
this.database = null;
}
Model.prototype.getDB = function(callback) {
if (this.database != null)
callback(this.database);
else {
console.log("Connecting to database...");
this.database = require("db-mysql").Database({
"hostname" : "localhost",
"user" : "root",
"password" : "pass",
"database" : "miku",
}).on("ready", function() {
console.log("Database ready, saving for further use.");
this.database = this;
callback(this);
});
}
}
exports.Model = Model;
我用于测试的简单代码:
orm = require('./orm');
model = new orm.Model();
model.getDB(function (db) { console.log("callback'd"); });
它看起来很好(至少对我来说),但是node.js因内部断言而失败:
Connecting to database...
node: /usr/include/node/node_object_wrap.h:61: void node::ObjectWrap::Wrap(v8::Handle<v8::Object>): Assertion `handle->InternalFieldCount() > 0' failed.
Przerwane (core dumped)
进一步调查后,如果在创建Database对象之前/期间失败。我不知道为什么会这样。我首先是因为我使用的是git node.js版本,但它也失败了当前版本(v0.4.7)。
我正试图在node.js代码中追踪这个问题,目前没有成功。
答案 0 :(得分:3)
哦,是我努力地失败了。似乎在JavaScript世界中使用Python背景是不受欢迎的;)。
数据库初始化应如下所示:
db = require("db-mysql");
new db.Database({
"hostname" : "localhost",
"user" : "root",
"password" : "pass",
"database" : "miku",
}).on("ready", function() {
console.log("Database ready, saving for further use.");
this.database = this;
callback(this);
}).connect();
所以,我基本上忘了拨打new
和connect()
。