在node.js中访问MySQL数据库 - 内部断言失败

时间:2011-05-14 11:52:24

标签: javascript mysql node.js

我正在尝试使用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代码中追踪这个问题,目前没有成功。

1 个答案:

答案 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();

所以,我基本上忘了拨打newconnect()