从db获取简单信息到node.js http服务器响应

时间:2011-05-21 10:28:09

标签: mysql node.js

我试图从db获取一个简单的信息到node.js http服务器响应。 在下面的代码片段中,我可以在系统日志中看到数据库结果,但不会在http响应中看到。

你能告诉我为什么会这样吗?

感谢。

var
    sys = require( 'sys' )
    , http = require( 'http' )
    , dbParams = {
          user : 'test'
        , pass : 'test'
        , db : 'just_test'
    }
;

function dbConnect() {
    var Client = require( 'mysql' ).Client
        , client = new Client()
    ;

    client.user = dbParams.user;
    client.password = dbParams.pass;
    client.connect();
    client.query('USE ' + dbParams.db);

    return( client );
}

var dbClient = dbConnect();

http.createServer( function( httpRequest, httpResponse ) {
    httpResponse.writeHead( 200, { 'Content-Type' : 'text/plain' } );
    httpResponse.write( '=== START httpResponse' + "\n" );

    dbClient.query( 'SELECT * FROM base_events', function (err, dbRes, fields) {
        if (err) { throw err; }

        httpResponse.write( 'Obtained: ' + JSON.stringify( dbRes ) );
sys.log( 'FROM DB: ' + JSON.stringify( dbRes ) );
    } );

    httpResponse.write( '=== Test' + "\n" );
    httpResponse.end();

    dbClient.end();
} ).listen( 8000 );

sys.puts( 'Server running at http://127.0.0.1:8000' );

1 个答案:

答案 0 :(得分:5)

在结束httpResponse后调用client.query的异步回调。尝试移动回调中的最后几个语句 - 例如:

http.createServer( function( httpRequest, httpResponse ) {
    httpResponse.writeHead( 200, { 'Content-Type' : 'text/plain' } );
    httpResponse.write( '=== START httpResponse' + "\n" );

    dbClient.query( 'SELECT * FROM base_events', function (err, dbRes, fields) {
        if (err) { throw err; }

        httpResponse.write( 'Obtained: ' + JSON.stringify( dbRes ) );
    sys.log( 'FROM DB: ' + JSON.stringify( dbRes ) );

        httpResponse.write( '=== Test' + "\n" );
        httpResponse.end();

        dbClient.end();

    } );

} ).listen( 8000 );