knex.js db调用未完成

时间:2015-03-05 02:49:00

标签: javascript node.js knex.js

我正在学习node.js并遇到了knex.js和bookshelf.js来与不同的数据库进行交互。我试图运行一个简单的knex程序,但不知何故该程序不会退出。以下是该计划:

'use strict';
console.log('Getting knex');
var knex = require('./knex')({
  client: 'mysql',
  connection: {
    host: '127.0.0.1',
    user: 'shankhoneer',
    password: 'password',
    database: 'knex_test'
  }
});
debugger;
console.log('got knex');
knex.schema.createTable('users', function(table) {
  console.log('creating tables');
  table.increments('id');
  table.string('user_name');
}).then (function(msg){
  console.log('Completed creation');
  console.log(msg);
  return {inserted: true};
});

我试图调试并发现knex使用蓝鸟承诺。我的问题是由于承诺退出不完整吗? 感谢

1 个答案:

答案 0 :(得分:16)

这是因为与数据库的连接仍然是打开的。 在上一个.then( ... )之后添加以下代码,它将断开连接(从而退出流程):

.finally(function() {
  knex.destroy();
})