Edited at

Node.jsのMySQLでAsync/Awaitしたらプロセスが終わらない

Node.jsのMySQLでAsync/Awaitしたら、データの取得はうまくいったけどプロセスがいつもまで経っても終わらなかったのでメモ。

Node.jsのMySQLでAsync/Awaitについてはこちらの記事を参考にさせていただきました。

Node.jsのMySQLでAsync/Awaitする方法


プロセスが終わらないコード

const mysql = require('mysql');

const util = require('util');

// 取得
async function findRecord(id) {
var pool = mysql.createPool({
host: ' *** ',
user: ' *** ',
password: '***',
database: ' *** ',
})
pool.query = util.promisify(pool.query)
try {
var records = await pool.query('SELECT * FROM xxxx WHERE id = ' + id);
return records[0];
} catch (err) {
throw new Error(err)
}
}

(async () => {
const record = await findRecord(1);
console.log(record);
})();


なぜプロセスが終わらないのか

mysqlのコネクションが残ったままになっていると仮定し、コネクションを終了させたところ、解決しました。


完成したコード

const mysql = require('mysql');

const util = require('util');

// 取得
async function findRecord(id) {
var pool = mysql.createPool({
host: ' *** ',
user: ' *** ',
password: '***',
database: ' *** ',
})
pool.query = util.promisify(pool.query)
try {
var records = await pool.query('SELECT * FROM xxxx WHERE id = ' + id);
pool.end();// ←これです
return records[0];
} catch (err) {
throw new Error(err)
}
}

(async () => {
const record = await findRecord(id);
console.log(record);
})();