今天做商城项目的时候,需要将用户的待付款订单一个小时后自动取消。那么这个操作,不可能是人为的,只能借助
linux
的cron
来进行做定时任务了。
整体思路:
首先,在 Order
模型里写一个 public
方法,将查询到的半个小时之外还没付款的订单,将其状态全部改为 已取消的状态。
其次,自定义命令,执行该方法。
最后呢,就是将其命令注册到调度任务里自动执行即可。
1.编写public cancelUnpaidOrder的方法
// 在Order模型里
public function cancelUnpaidOrder() {
self::where('status', 1)
->where('created_at', '<=', date('Y-m-d H:i:s',time() - 30 * 60))
->update(['status' => 0]);//我这里的状态为0 就是代表取消订单
//清除缓存(一般做了缓存的这里得清除一下)
Cache::forget('status_counts_'.Auth::id());
Cache::forget('count_all'.Auth::id());
}
2.自定义命令