自问自答系列——商城相关

前情提要:最近想做个卖个人想法的网站,姑且可以称为头脑风暴聚集地。每个人都有一些新奇的想法,过一段时间就忘了,为什么不出售他们呢?OK,有点脱离主题了,因为想自己做一个简单的商城玩玩,顺便用下Laravel的新版本(喜欢尝鲜),稍微总结一下。

问题抛出:商品的表应该怎么设计?

一般情况下,我个人习惯将商品信息和规格分成两张表。商品信息表(记录除规格的相关信息)和商品规格表(记录规格)。了解商品与商品 SKU 的关系的一般都会将商品的信息和规格(单品)分开,当然不是绝对的,曾经有人争论过,这里不多说。

问题抛出:订单号生成应该注意哪些?

一般来说,订单号都是年月日时分秒+随机数生成的。随机数位数的多少在于并发考虑,比如,每秒10万访问量,就是6位随机数。那有没有可能重复呢?当然是有可能得,万一同一秒随机出两个一样的呢对不对,所以我们可以把生成的这个过程放在一个for循环里面,然后再去数据库里面查询加以判断。

public static function creatNo()
    {
        // 订单流水号前缀
        $prefix = date('YmdHis');
        for ($i = 0; $i < 10; $i++) {
            // 随机生成 6 位的数字,不足6位的在右边补0
            $no = $prefix.str_pad(random_int(0, 999999), 6, '0', STR_PAD_RIGHT);
            // 判断是否已经存在,如果不存在返回订单号,存在记录日志
            if (!static::query()->where('no', $no)->exists()) {
                return $no;
            }
        }
        \Log::warning('find order no failed');

        return false;
    }

问题抛出:生成订单的时候应该考虑哪些因素?

当我们创建订单的时候,我们首先应该考虑订单号有没有重复,当然这个我们在生成订单号的时候已经判断了。接着我们应该考虑商品存不存在,商品有没有上架,商品有没有库存,最后再判断购买的数量我们的库存是否不足。这些不太建议写在Controller里面,这可能会造成控制器的臃肿,我们可以写在Request里面。

问题抛出:下单后不支付该怎么处理?

这里我们可以用队列任务,比如设定半小时不支付就关闭订单。我想这个处理方法时比较好的。

问题抛出:控制器太臃肿怎么办?

推荐使用Service 模式,推荐一篇文章如何使用Service模式?

欢迎指正;欢迎补充;欢迎留言 ——@Jouzeyu

本作品采用《CC 协议》,转载必须注明作者和本文链接
空舟湖上~      ——Jouzeyu
lochpure
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
讨论数量: 2

还不错,感觉编程代码是其次的,关键还是思路

4年前 评论

如果存在了应该再调一次creatNo方法吧

// 判断是否已经存在,如果不存在返回订单号,存在记录日志
            if (!static::query()->where('no', $no)->exists()) {
                return $no;
            }
4年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!