微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Postgres / Typeorm / Express:如何为来自多个客户端的同时请求保持数据库一致?

如何解决Postgres / Typeorm / Express:如何为来自多个客户端的同时请求保持数据库一致?

我正在使用 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

请求迟到的客户端将无法增加该值,并将在响应中返回错误,注意到配额已全部用完。

一些想法:

  1. 在 Typeorm / Postgres 中,有没有办法为一列整数值设置上限?这样,如果将值设置为某个超出上限的值,则会引发错误

  2. 我正在考虑限制执行增量的端点,以便一次只调用一次。鉴于上述第 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)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。