Ich bin der Autor von pg-promise;)
con.task(t => {
const a = post => t.any('SELECT * FROM comment WHERE idPost = $1', post.id)
.then(comments => {
post.comments = comments;
return post;
});
return t.map('SELECT *, avatar FROM post, users WHERE user = $1 AND user = alias ORDER BY time DESC LIMIT 10 OFFSET $2', [username, pos], a)
.then(t.batch);
})
.then(posts => {
res.send(posts);
})
.catch(error => {
console.log(error);
});
Siehe auch diese Frage:JOIN-Tabelle als Array von Ergebnissen mit PostgreSQL/NodeJS abrufen.
AKTUALISIEREN
Falls Sie nicht den ganzen Weg mit dem JSON-Abfrageansatz gehen möchten, wird das Folgende viel besser skalieren als die ursprüngliche Lösung, da wir alle untergeordneten Abfragen verketten und sie dann als eine Abfrage ausführen:
con.task(async t => {
const posts = await t.any('SELECT *, avatar FROM post, users WHERE user = $1 AND user = alias ORDER BY time DESC LIMIT 10 OFFSET $2', [username, pos]);
const a = post => ({query: 'SELECT * FROM comment WHERE idPost = ${id}', values: post});
const queries = pgp.helpers.concat(posts.map(a));
await t.multi(queries)
.then(comments => {
posts.forEach((p, index) => {
p.comments = comments[index];
});
});
return posts;
})
.then(posts => {
res.send(posts);
})
.catch(error => {
console.log(error);
});
Siehe API:
- helpers.concat
- Datenbank.multi