gpt4 book ai didi

javascript - Pg-promise:链接条件查询

转载 作者:行者123 更新时间:2023-11-30 13:52:30 24 4
gpt4 key购买 nike

我正在尝试找到链接条件查询的正确方法。

下面是一些伪代码来说明我的情况:

check whether the an item exists;
if no:
reply with status 404;
if yes:
check whether the user owns the item;
if no:
redirect to another page;
if yes:
retrieve the information about the item and render the page;

我的第一直觉是使用 tasks为了重用相同的连接,但由于可能的结果不同,我很难弄清楚如何正确处理 promise :

db.task(t => {
return t.items.exists(itemId)
.then(exists => {
if (!exists) { // item does not exist
// 404
}

return t.items.isOwner(itemId, userId)
.then(isOwner => {
if (!isOwner) {
// redirect to some other page
}

return t.items.getById(itemId);
})
})
})
.then(data => {
// OK, process data and render
})
.catch(console.error); // unexpected errors

例如,如果我尝试重定向到 404 页面, promise 仍将在之后得到解决。另一种方法是具有以下内容:

if (!exists) { // item does not exist
return Promise.reject('404');
}

...

.then(data => {
// OK, process data and render
}, reason => {
// KO, conditions were not met to resolve
})

哪个“有效”,但同时捕获错误和未满足的条件。我更愿意有一个专门的“未满足条件”处理程序。

我想到的另一种方法:

var p = db.task(t => {
return t.items.exists(itemId)
.then(exists => {
if (!exists) { // item does not exist
// resolve p (and break promise chain) with something like
// p.resolve(() => {
// return res.redirect...
// });
}

// else we can go on with the queries
return t.items.isOwner(itemId, userId);
}
.then(isOwner => {
if (!isOwner) {
// resolve p and redirect to some other page
}

return t.items.getById(itemId);
})
.then(item => {
// everything OK, resolve with a handler to render the page
});
})
.then(action => {
action();
})
.catch(console.error); // unexpected errors

但我看不出有什么方法可以解析 p。在嵌套的 promise 中调用 Promise.resolve(...) 会在落入 pthen 之前自行解析下一个 promise。

在关注性能的同时,在 pg-promise 中链接条件查询和处理不同结果的推荐方法是什么?

最佳答案

作者的问题主要是使用 promise ,而不是 pg-promise .

db.task('easy-peasy', async t => {
if (await t.items.exists(itemId)) {
// reply with status 404;
} else {
if (await t.items.isOwner(itemId, userId)) {
// redirect to some other page
} else {
return t.items.getById(itemId); // return the data
}
}
})
.then(data => {
if (data) {
// Task returned data;
// Render the data;
}
})
.catch(console.error); // unexpected errors

关于javascript - Pg-promise:链接条件查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57967135/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com