问题描述
我正在使用 Express / Typescript / Typeorm / Postgres 为我的应用构建后端。
假设我有一个名为 Restaurant
的表,其中包含以下列:
restaurant_id
order (Integer)
quota (Integer)
这个想法是每家餐厅都有一个它可以接收的订单数量的上限。多个客户可以向餐厅发送订单,从而将 order
加一。
如果餐厅目前:
id: 1
order : 9
quota : 10
两个客户同时向它发送订单,有问题。
我希望它的行为使得无论哪个请求先到达,成功地将 order
值加一,结果:
id: 1
order : 10
quota : 10
请求迟到的客户端将无法增加该值,并将在响应中返回错误,注意到配额已全部用完。
一些想法:
-
在 Typeorm / Postgres 中,有没有办法为一列整数值设置上限?这样,如果将值设置为某个超出上限的值,则会引发错误?
-
我正在考虑限制执行增量的端点,以便一次只调用一次。鉴于上述第 1 点可行,我仍然希望在某些其他情况下禁用端点的并行执行。
(这不是运行代码,只是一些参考):
app.put('/restaurant_order/:restaurantId',async (req,res) => {
const instance = await Restaurant.findOne(restaurantId);
if (instance.order < instance.quota){
await getConnection()
.createqueryBuilder()
.update(Restaurant)
.set({ order: () => `order + 1` })
.where("id = :id",{ id: restaurantId })
.execute();
}
res.respond({
...
})
});
问题变成了:
如何在 Express 中设置此限制?
我可以将 Express 配置为 app.put('/restaurant_order/:restaurantId',...)
禁止并行调用,并且每个 restaurantId
一次只允许一个调用吗?
解决方法
首先,阅读文档的相关部分:https://www.postgresql.org/docs/8.3/ddl-constraints.html
示例:
CREATE TABLE products (
product_no integer,name text,price numeric CHECK (price > 0)
);
在你的情况下,这将是
order integer CHECK (order < quota)