如何在nodejs中计算每天的限价订单
How to calculate limit order per day in nodejs
我有一个需要每天限价订单的业务场景。
例如,
产品架构:
产品名称,
limitPerDay=2,....
所有者可以为产品设置 limitPerDay。
用户可以订购产品或预订产品(1小时)。
如果超出限制,用户将能够在产品列表中看到超出限制的标签。
例如。有三个用户 Adam、Bob 和 Tom。 Adam 预订产品 LAPTOP,Bob 订购产品 LAPTOP。 Tom 将无法预订或订购 LAPTOP,因为已超过限制(TOM 可以看到产品,但会看到 LIMIT EXCEEDED 标签,并且限制将在 1 小时后开放,因为 Adam 已预订 1 小时)。
场景一:一个小时过去了,Adam 没有购买,他的预订现在已经结束。 TOM 可以看到可用性并订购产品。
场景 2:Adam 从其保留列表中购买,现在 ADAM 和 BOB 都已订购。 TOM 必须等待接下来的 24 小时才能购买该产品。
如何存储这些购买和预订以启用我需要的逻辑。我正在使用 MongoDb 来存储数据
大多数网站不反映实时变化。通常用户必须刷新页面,
为了查看最近的变化。
我们的数据库模式是:
{
_id: <product_id>,
orders: [<user_id>],
order_count: number,
reserves: [reserved],
reserves_count: number,
}
reserved {
_id : <user_id>,
time: Data,
}
所以当用户请求产品时,服务器需要做检查,
- 当前时间 -
product.reserves.reserver.time
= 如果超过 1 小时则更新 reserves_count
- limitedOrderRequest -
product.order_count
+ product.reserves_count
= 0;用户必须等待 24 小时...
更新文档时:
- limitedOrderRequest -
product.order_count
= 如果为 0 则用户无法订购
- limitedreserveRequest -
product.reserves_count
= 如果为 0,则用户无法预订。
我有一个需要每天限价订单的业务场景。 例如,
产品架构: 产品名称, limitPerDay=2,....
所有者可以为产品设置 limitPerDay。
用户可以订购产品或预订产品(1小时)。 如果超出限制,用户将能够在产品列表中看到超出限制的标签。
例如。有三个用户 Adam、Bob 和 Tom。 Adam 预订产品 LAPTOP,Bob 订购产品 LAPTOP。 Tom 将无法预订或订购 LAPTOP,因为已超过限制(TOM 可以看到产品,但会看到 LIMIT EXCEEDED 标签,并且限制将在 1 小时后开放,因为 Adam 已预订 1 小时)。
场景一:一个小时过去了,Adam 没有购买,他的预订现在已经结束。 TOM 可以看到可用性并订购产品。
场景 2:Adam 从其保留列表中购买,现在 ADAM 和 BOB 都已订购。 TOM 必须等待接下来的 24 小时才能购买该产品。
如何存储这些购买和预订以启用我需要的逻辑。我正在使用 MongoDb 来存储数据
大多数网站不反映实时变化。通常用户必须刷新页面, 为了查看最近的变化。
我们的数据库模式是:
{
_id: <product_id>,
orders: [<user_id>],
order_count: number,
reserves: [reserved],
reserves_count: number,
}
reserved {
_id : <user_id>,
time: Data,
}
所以当用户请求产品时,服务器需要做检查,
- 当前时间 -
product.reserves.reserver.time
= 如果超过 1 小时则更新reserves_count
- limitedOrderRequest -
product.order_count
+product.reserves_count
= 0;用户必须等待 24 小时...
更新文档时:
- limitedOrderRequest -
product.order_count
= 如果为 0 则用户无法订购 - limitedreserveRequest -
product.reserves_count
= 如果为 0,则用户无法预订。