关于生成订单号的问题

/**
     * 生成分期流水号
     *
     * @return bool|string
     * @throws \Exception
     */
    public static function findAvailableNo()
    {
        // 分期流水号前缀
        $prefix = date('YmdHis');
        for ($i = 0; $i < 10; $i++) {
            // 随机生成 6 位的数字
            $no = $prefix . str_pad(random_int(0, 999999), 6, '0', STR_PAD_LEFT);
            // 判断是否存在
            if (!static::query()->where('no', $no)->exists()) {
                return $no;
            }
        }
        \Log::warning(sprintf('find installment no failed'));

        return false;
    }

疑问一:循环为何定义为 10 次?
疑问二:每次生成都要做数据库查询,是否对性能影响太大了,比如抢购之类的业务场景,并发量大的时候如何快速的确保订单号的唯一?

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
leo
最佳答案
  1. 总要定一个数字,不然有可能出现死循环
  2. 等你看到后面的秒杀模块的时候就知道根本不会有多少个订单被创建,所以不需要考虑这个问题。
6年前 评论
yadan 4年前
leo (作者) 4年前
yadan 4年前
讨论数量: 2
leo
  1. 总要定一个数字,不然有可能出现死循环
  2. 等你看到后面的秒杀模块的时候就知道根本不会有多少个订单被创建,所以不需要考虑这个问题。
6年前 评论
yadan 4年前
leo (作者) 4年前
yadan 4年前

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