超时未支付算不算取消一次订单_订单超过二十四小时未付款,就取消,实现该功能的几种姿态...

本文主要是介绍超时未支付算不算取消一次订单_订单超过二十四小时未付款,就取消,实现该功能的几种姿态...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

efa014da920c

网上商城有一个很常见的应用场景:一个订单未付费,二十四小时后自动取消,这个在程序上如何实现,有几种实现方法,每种方法的利弊是什么?

第一种方法:写个定时任务,在某个时间节点,定时检索订单表,有超过二十四小时的订单,统统修改为订单已取消;

实现难易程度:很容易实现,写个定时任务就可以了。

利:不会漏掉订单,只要是超过二十四小时未付款的订单,都可以被检索到、取消掉。

弊:不管有没有订单生成,有没有超过二十四小时未付款的订单,到了时间就必须去数据库检索。另外定在一个特定的时间点去执行数据库查询,会有过期未付款的订单处理的没那么及时。

定时任务代码实现参考:

第二种方法:在订单生成的时候,就把订单号放在缓存里,或是异步任务里,让它等待二十四小时;二十四小时后,再根据订单号去数据库中检索,查看该订单是否付款,如果已经付款了,操作结束;否则,执行订单取消的动作。

实现难易程度:很容易实现,写个异步的任务,到点后,再跟踪该订单的付款状态就可以了。

利:没有订单生成,就不用去数据检索;有订单生成,到点后,才根据订单号去数据库检索,检索到了未付款的订单,再做取消订单的动作。

弊:放在缓存里,或异步任务里,如果遇到服务器异常,被迫重启了,那么这个订单号就丢失了,就会有遗漏的该取消却未取消的订单。如果生成的订单很多,那么就会堆积很多异步任务,会不会影响性能呢,不好说。

线程代码实现参考:

睡二十四个小时,如何睡?

代码实现一:

public static void main(String[] argo){

try {

for(int i=0;i<10;i++){

//睡3秒钟,24小时 = 24 * 60 * 60 * 1000

System.currentTimeMillis();

Thread.sleep(3*1000);

System.out.println(System.currentTimeMillis() + ":" +i);

}

} catch (InterruptedException e) {

e.printStackTrace();

}

}

打印执行结果:

1605789092882:0

一句代码,就让它睡了。

二十四后执行,不一定睡,还可以使用 Java定时器

代码实现二:

/**

* 测试用例,java定时器

* @param argo

*

*/

public static void main(String[] argo){

System.out.println(System.currentTimeMillis());

Timer timer = new Timer();

timer.schedule(new TimerTask(){

@Override

public void run() {

System.out.println(System.currentTimeMillis() + ": 执行任务");

}

}, 3 *1000); //3秒后执行,24小时 = 24 * 60 * 60 * 1000

}

执行结果:

1605789480093

以上两种方法都有不足之处,一个耗费性能,没有订单也要白白执行了一次数据库查询;另一个担心服务器重启,还需要补救措施。

在实际操作中,也可以使用第一种方法,忽略对性能的影响;也可以使用第二种,忽略服务器的重启,或者做补救措施,对遗漏的超时未付款订单人工处理,这就需要在管理后台有个操作订单的界面了。

还有没有其他更好的处理方式呢,当然是有的,比如结合redis的使用,利用redis的过期机制,这也是一种思路。

相关redis使用参考

这篇关于超时未支付算不算取消一次订单_订单超过二十四小时未付款,就取消,实现该功能的几种姿态...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/161952

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima