koa 和 sqlite3 节点 REST 端点只返回数据库对象而不是数据
koa and sqlite3 node REST endpoint returning only Database object instead of data
我有一个使用 Koa 和 sql3lite 的简单 GET 路由设置,它使用包装器从 json 文件中获取一些数据。
帮助程序 sql3lite 包装器公开了主服务器 index.js
文件的初始化函数以在启动时加载到内存中:
index.js
const data = require('./data');
data.initialize();
const server = createServer();
server.listen(PORT, () => {
console.log(`server listening on port ${PORT}`);
});
data.js
文件作为 sqlite3 节点库的包装器,因此路由可以单独调用 connection()
方法。
data.js
const connection = new sqlite3.Database(':memory:');
function initialize() {
connection.serialize(() => {
connection.run('CREATE TABLE meter_reads (cumulative INTEGER, reading_date STRING, unit STRING)');
const { electricity } = sampleData;
electricity.forEach((data) => {
connection.run(
'INSERT INTO meter_reads (cumulative, reading_date, unit) VALUES (?, ?, ?)',
[data.cumulative, data.readingDate, data.unit],
);
});
});
}
module.exports = {
initialize,
connection,
};
我遇到的问题是在调用导出的connection
方法时将数据对象发送回客户端或邮递员:
koa航线
const db = require('../data');
router.get('/meter/readings', async (ctx, next) => {
ctx.body = await db.connection.all('SELECT * FROM meter_reads', (err, data) => data);
});
获取路由结果的请求:
{
"open": true,
"filename": ":memory:",
"mode": 65542
}
有趣的怪癖:
通过用 console.log()
包装上面 db.connection.all()
方法生成的 data
对象,我可以在节点服务器上打印出预期的数据。就好像 ctx.body
搞砸了什么。到目前为止,我一直是一个快递员,如果这是一个菜鸟错误,我深表歉意!
GMS 在这里回答:
https://github.com/mapbox/node-sqlite3/issues/1046#issuecomment-425643910
'all' 没有 return 任何值(它 return 是调用给定回调的结果)所以你实际上在等待这行代码中的 'db.connection'
有一些基于 node-sqlite3 的库提供基于 API 的承诺等等
例如
https://www.npmjs.com/package/sqlite
或我的:
https://www.npmjs.com/package/sqlite3orm
我有一个使用 Koa 和 sql3lite 的简单 GET 路由设置,它使用包装器从 json 文件中获取一些数据。
帮助程序 sql3lite 包装器公开了主服务器 index.js
文件的初始化函数以在启动时加载到内存中:
index.js
const data = require('./data');
data.initialize();
const server = createServer();
server.listen(PORT, () => {
console.log(`server listening on port ${PORT}`);
});
data.js
文件作为 sqlite3 节点库的包装器,因此路由可以单独调用 connection()
方法。
data.js
const connection = new sqlite3.Database(':memory:');
function initialize() {
connection.serialize(() => {
connection.run('CREATE TABLE meter_reads (cumulative INTEGER, reading_date STRING, unit STRING)');
const { electricity } = sampleData;
electricity.forEach((data) => {
connection.run(
'INSERT INTO meter_reads (cumulative, reading_date, unit) VALUES (?, ?, ?)',
[data.cumulative, data.readingDate, data.unit],
);
});
});
}
module.exports = {
initialize,
connection,
};
我遇到的问题是在调用导出的connection
方法时将数据对象发送回客户端或邮递员:
koa航线
const db = require('../data');
router.get('/meter/readings', async (ctx, next) => {
ctx.body = await db.connection.all('SELECT * FROM meter_reads', (err, data) => data);
});
获取路由结果的请求:
{
"open": true,
"filename": ":memory:",
"mode": 65542
}
有趣的怪癖:
通过用 console.log()
包装上面 db.connection.all()
方法生成的 data
对象,我可以在节点服务器上打印出预期的数据。就好像 ctx.body
搞砸了什么。到目前为止,我一直是一个快递员,如果这是一个菜鸟错误,我深表歉意!
GMS 在这里回答: https://github.com/mapbox/node-sqlite3/issues/1046#issuecomment-425643910
'all' 没有 return 任何值(它 return 是调用给定回调的结果)所以你实际上在等待这行代码中的 'db.connection' 有一些基于 node-sqlite3 的库提供基于 API 的承诺等等 例如 https://www.npmjs.com/package/sqlite 或我的: https://www.npmjs.com/package/sqlite3orm