如何在nodejs中计算每天的限价单

Posted

技术标签:

【中文标题】如何在nodejs中计算每天的限价单【英文标题】:How to calculate limit order per day in nodejs 【发布时间】:2021-07-07 18:32:15 【问题描述】:

我有一个需要每天限价订单的业务场景。 例如,

产品架构: 产品名称, limitPerDay=2,....

所有者可以为产品设置 limitPerDay。

用户可以订购产品或预订产品(1小时)。 如果超出限制,用户将能够在产品列表上看到 LIMIT EXCEEDED 标签。

例如。共有三个用户 Adam、Bob 和 Tom。 Adam 预订产品 LAPTOP,Bob 订购产品 LAPTOP。 Tom 将无法预订或订购笔记本电脑,因为已超出限制(TOM 可以看到产品,但会看到标签 LIMIT EXCEEDED,并且限制将在 1 小时后打开,因为 Adam 已预订 1 小时)。

场景 1:一小时过去了,Adam 没有购买,他的预订现在已经结束。 TOM 可以查看可用性并订购产品。

场景 2:Adam 从它的保留列表中进行购买,现在 ADAM 和 BOB 都已订购。 TOM 将不得不等待接下来的 24 小时才能购买该产品。

我如何存储这些购买和预订以启用我需要的逻辑。我正在使用 MongoDb 来存储数据

【问题讨论】:

【参考方案1】:

大多数网站不反映实时变化。通常用户必须刷新页面, 为了查看最近的变化。

我们的数据库架构是:


    _id: <product_id>,
    orders: [<user_id>],
    order_count: number,
    reserves: [reserved],
    reserves_count: number,

reserved 
    _id : <user_id>,
    time: Data,

所以当用户请求产品时,服务器需要做检查,

currentTime - 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,则用户无法预订。

【讨论】:

感谢您的解决方案。不过,我对这个问题使用了不同的方法。我创建了另一个储备集合并使用 cron-job

以上是关于如何在nodejs中计算每天的限价单的主要内容,如果未能解决你的问题,请参考以下文章

如何向币安发送 OCO 订单

金融量化什么叫市价单限价单和停止单?

金融量化什么叫市价单限价单和停止单?

金融量化什么叫市价单限价单和停止单?

coinbase pro API - 我可以更新未平仓限价单吗?

限价委托和市价委托有啥 区别?如何 使用?