データベースから値を取得しようとしています。デモの例で試してみてください。しかし、コールバック関数を使用して、呼び出しを同期するのに問題があります。私はnode.jsの初心者なので、これが正しい方法かどうかわかりません。
ファイル1:app.js
var data;
var db = require('./db.js');
var query = 'SELECT 1 + 1 AS solution';
var r = db.demo(query, function(result) { data = result; });
console.log( 'Data : ' + data);
ファイル2:db.js
var mysql = require('./node_modules/mysql');
var connection = mysql.createConnection({
host : 'localhost',
user : 'root',
password : 'root',
});
module.exports.demo = function(queryString, callback) {
try {
connection.connect();
console.log('Step 1');
connection.query(queryString, function(err, rows, fields) {
console.log('Step 2');
if (err) {
console.log("ERROR : " + err);
}
console.log('The solution is: ', rows[0].solution);
callback(rows[0].solution);
return rows[0].solution;
});
callback();
connection.end();
console.log('Step 3');
}
catch(ex) {
console.log("EXCEPTION : " + ex);
}
};
出力:
Step 1
Step 3
Data : undefined
Step 2
The solution is: 2
この質問も参照しましたが、私の問題は解決しませんでした: コールバックからのnodeJSの戻り値