Как вернуть результат sql-запроса [дубликат]

213
22 февраля 2017, 23:12

На данный вопрос уже ответили:

  • Как вернуть значение из события или из функции обратного вызова? 2 ответа

Есть функция. Сервер node.js должен вернуть результат sql-запроса, но из-за асинхронной природы js у меня не получается вернуть результат через то что не успевает отработать база. До этого работал с синхронными языками у меня беда.

function getCollections()
{
    res = 0;
    var conn = new sql.Connection(dbConfig);
    conn.connect().then(function (recordset)
    {
        var req = new sql.Request(conn);
        req.query("SELECT * FROM Collections").then(function (recordset)
        {
            conn.close();
            res = recordset;
        })
        .catch(function (err)
        {
            console.log(err);
            conn.close();
        })
    })
    .catch(function (err)
    {
        console.log(err);
    });
    while (res === 0) { console.log(1);}
}
app.get("/", function (request, response) {    
    var res = getCollections();
    response.send(res);
});
Answer 1

Ваша библиотека для работы с базой данных позволяет вам писать Promise-like код. Так почему бы просто не вернуть Promise из getCollections?

Например вот так:

function getCollections() {
    var conn = new sql.Connection(dbConfig);
    return conn.connect().then(function (recordset) {
        var req = new sql.Request(conn);
        return req.query("SELECT * FROM Collections").then(function (recordset) {
            conn.close();
            return Promise.resolve(recordset);
        }).catch(function (err) {
            conn.close();
            return Promise.reject(err);
        });
    });
}

Тогда функция обработки запроса могла бы иметь вид:

app.get("/", function (request, response) {    
    getCollections().then(function (records) {
        response.json(records);
    }).catch(function (error) {
        response.status(500).json({error: error.toString()});
    });
});
Answer 2

Закиньте response.send(res); в getCollections. Например:

getCollections(request, response);

а в `req.query("SELECT * FROM Collections").then(function (recordset)

  conn.close();
  res = recordset;
  response.send(res);

а в catch's 400

response.statusCode = 400;
response.setHeader('Content-Type', 'application/json');
response.send(JSON.stringify({status:'error', message: 'some error'}));
READ ALSO
Оффлайн поиск текста по заголовкам на Javascript

Оффлайн поиск текста по заголовкам на Javascript

Есть папка с HTML-ФайламиПросто папка, лежащая прямо у пользователя, без вебсервера

255
Не работает функция Jquery?

Не работает функция Jquery?

Есть две кнопки

270
Калькулятор с коэфицентом

Калькулятор с коэфицентом

Есть 2 поля select, в каждом из них по 18 значений, от 1 до 18

225