我为数据库创建了配置文件,如下所示:
module.exports.connection = {
sqlserver: {
user: 'user_name',
password: 'password',
server: 'servername\\instancename',
database: 'database_name',
port: 1433,
},
};
我在数据库中有一个简单的表:
我正在尝试从上表中获取数据,如下所示:
const sql = require('mssql');
const config = require('../config/connection');
sql.connect(config.connection.sqlserver).then((pool) => pool.request().query('select type from dbo.category')).then((result) => {
console.log(result);
}).catch((err) => {
console.log(err);
});
sql.close();
不幸的是,我在控制台中没有看到任何东西,也没有任何错误,所以我找不到问题所在。 我也试过:
sql.connect(config.connection.sqlserver).then((pool) => pool.request().query('select type from dbo.category')).catch((err) => {
console.log(err);
}).then((result) => {
console.log(result);
}).catch((err) => {
console.log(err);
});
sql.close();
我用了https://www.npmjs.com/package/mssql#promises .我正在尝试在我的 nodeJs 服务器上执行此操作。有什么想法吗?
最佳答案
我解决了我的问题。感谢 Julia Shestakova 的建议。 我的查询函数如下所示:
const sql = require('mssql');
const config = require('./config/connection');
module.exports = {
query(query) {
return sql.connect(config.connection.sqlserver).then(() => sql.query(query)).then((result) => {
sql.close();
return result.recordset;
}).catch((err) => console.log(err));
},
};
我正在返回 Promise,这样当我在服务器上调用查询函数时,我可以使用 then
来呈现我的数据。
关于javascript - MS SQL 不返回 NodeJS 中的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58203320/